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ГЛАВА IS 

НАБОР КОМАНД СИСТЕМЫ SWARD 

В этой главе рассматривается основной набор команд системы 
SWARD. Для большинства команд справедливы следующие об¬ 
щие замечания. 

1. Если операндами команд являются два массива, они 
должны быть конформными друг другу, т. е. иметь одинаковую 
размерность и равное количество элементов по соответствую¬ 
щим размерностям. Это же утверждение относится и к срезам 
массивов. Во всех случаях, когда указывается, что операндом 
команды является массив, если отсутствует специальная оговор¬ 
ка, операндом может быть и срез массива (множество значе¬ 
ний одноименных компонентов записей, являющихся элемента¬ 
ми массива). 

2. Если операндами команд являются две записи, у них 
должны быть одинаковые атрибуты, т. е. записи должны со¬ 
держать одинаковое количество элементов и соответствующие 
компоненты должны иметь одинаковые атрибуты (теги). 

3. Если операндом команды может быть ячейка определен¬ 
ного типа, в качестве операнда может использоваться и ячейка 
с вложенным тегом (тегами) 1 ). Например, если операнд дол¬ 
жен представлять собой целое число, адрес операнда может 
быть адресом ячейки, содержащей целое число, элемент мас¬ 
сива целых чисел, информацию о косвенном доступе к целочис¬ 
ленным данным, целочисленный параметр, целочисленный ком¬ 
понент записи, целочисленные данные, тип которых задается 
пользователем, и т. д. 

4. При выполнении многих команд могут регистрироваться 
ошибки, принадлежащие некоторому основному набору ошибок. 
В упомянутый набор ошибок входят ошибки следующих типов: 


*> Вложенный тег должен совпадать с тегом для типа ячейки, указанного 
в качестве допустимого для операнда. Это и иллюстрируется следующим при¬ 
мером. — Прим, перев. 



неправильная адресация, данные неизвестного формата, нару¬ 
шение защиты доступа, недействительный потенциальный ад¬ 
рес, выход индекса за допустимые границы, неверный тип опе¬ 
ранда, неопределенный операнд, несовместимые операнды, ими¬ 
тация ошибки и неопределенный доступ к операнду. 

5. Под операндом арифметического типа понимают любой из 
следующих операндов: целое число, целое число увеличенной 
разрядности, порядковое число, десятичное число с фиксиро¬ 
ванной точкой, десятичное число с плавающей точкой или ли¬ 
терал. Под операндом «строка» (или «поле») подразумевается 
строка (или поле), состоящая из символов или токенов. Под 
операндом символьного типа понимают поле или строку сим¬ 
волов. Операнд логического типа обозначает либо порядковые 
числа, имеющие значения 0 и 1, либо литералы с такими же 
значениями. 

6. В описаниях форматов команд первое поле содержит код 
операции. Длина этого поля составляет 1—5 токен в зависи¬ 
мости от конкретной команды. Для адреса операнда использу¬ 
ется мнемоническое обозначение ОА, для адреса команды — 
ІА. 

7. В качестве адресов операндов допускается использование 
литералов, кроме тех случаев, когда при выполнении команды 
значение операнда может быть изменено или когда операнд не 
может быть арифметическим (числовым) или логическим. 

8. Длиной поля символов или токенов считается значение в 
поле «размер» тега ячейки, длиной строки символов или токе¬ 
нов— значение в поле «длина» текущего содержимого ячейки. 

9. Применительно к системе SWARD представления о коман¬ 
дах как о «квантах» обработки не являются правомочными 1 *. 
В частности, ошибки некоторых типов могут повлечь получение 
частичных результатов, хотя никогда не смогут внести дезор¬ 
ганизацию на уровне основных объектов системы (например, 
проявиться в «потере» отдельных частей памяти или объектов). 
Кроме того, если две или более процесс-машин одновременно 
выполняют команды, адресующиеся к одним и тем же компо¬ 
нентам системы (например, к ячейке объекта «память дан¬ 
ных»), то система не гарантирует ни порядка их выполнения, 
ни того, что при их реализации не произойдет непредвиденный 
интерференционный эффект. 

10. Если при выполнении команды возможно появление не¬ 
скольких ошибок, то имеет место и регистрируется системой 
только одна из них без указания ее очередности (т. е. архитек- 


*> Иными словами, нельзя делать утверждение относительно команд, что 
они либо выполняются полностью, либо совсем не выполняются. — Прим, пе- 
рев. 
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турой системы SWARD не предусмотрено какое-либо упорядо¬ 
чение регистрации одновременно возникающих ошибок). 

11. В целях повышения практической эффективности работы 
системы при реализации микропрограмм для команд сравне¬ 
ния EQBF, NEBF, LTBF, LEBF, GTBF„ GEBF и SEARCH до¬ 
пускается небольшое отклонение от общего правила выявления 
неопределенных значений. В том и только в том случае, когда 
операнд является полем или записью (или массивом полей или 
записей), поле или запись, которые частично не определены, не 
вызовут появления ошибки «неопределенный операнд». В конк¬ 
ретной реализации системы такие операнды могут использовать¬ 
ся для команд сравнения, выполнение которых завершается 
признаком результата «не сравниваются» (неравенство операн¬ 
дов). Однако, если поле или запись полностью не определены, 
при выполнении команды регистрируется ошибка. 

КОМАНДЫ ОБЩЕГО НАЗНАЧЕНИЯ 
Имя команды. MOVE 

Выполняемая операция. Пересылка второго операнда (копиро¬ 
вание) на место первого операнда. 

Формат. 1, ОА, ОА 

Операнды *>. Оба операнда должны быть взаимно совместимы¬ 
ми, т. е. должны быть числами, полями или строками симво¬ 
лов или токенов, указателями или записями. Оба операнда мо¬ 
гут быть одновременно массивами (или их срезами); при этом 
предполагается пересылка значений между соответствующими 
элементами этих массивов. Возможна и такая ситуация, когда 
массивом является только первый операнд; тогда выполнение 
команды сводится к записи значений второго операнда на ме¬ 
сто каждого элемента первого операнда. 

Если оба операнда представляют собой числа разного типа 
или размера, то результат, размещаемый на месте первого опе¬ 
ранда, преобразуется в форму, соответствующую этому опе¬ 
ранду. При выполнении команды MOVE округления не произ¬ 
водится. Когда выполняется пересылка строки или поля в стро¬ 
ку, длина первого операнда устанавливается равной длине вто¬ 
рого операнда. Если пересылка производится в поле символов 
и второй операнд короче первого, то остальная (правая) часть 
первого операнда заполняется пробелами. Если же пересылка 


1 > В этом разделе описывается назначение всех полей адреса каждой 
рассматриваемой команды, а не только их подмножества, отвечающего вве¬ 
денному автором определению операнда (см. раздел «Форматы команд и спо¬ 
собы адресации» в гл. 14), которого автор, за незначительными исключения¬ 
ми (сравните нумерацию операндов в командах XMACHINE и TRACE), при¬ 
держивается и в этих описаниях. — Прим, перев. 
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осуществляется в поле токенов и второй операнд короче перво¬ 
го, избыточная (левая) часть первого операнда заполняется ну¬ 
лями. Допускаются любые сочетания операндов полей симво¬ 
лов, полей токенов, строк символов и строк токенов. При пере¬ 
сылке символов в поле или строку токенов или наоборот вы¬ 
полняется побитовое копирование (т. е. какое-либо преобразо¬ 
вание информации отсутствует, за исключением возможного 
изменения атрибута длины и заполнения соответствующими 
символами избыточных полей). 

Если одна запись пересылается в другую, у них должно 
быть одинаковое число компонентов и соответствующие ком¬ 
поненты должны иметь одинаковые атрибуты. Пересылка за¬ 
писи эквивалентна пересылке всех ее отдельных компонентов. 
Ошибки. Основной набор ошибок (за исключением «невер¬ 
ный тип операнда») и «переполнение». 

Имя команды. CONVERT 

Выполняемая операция. Пересылка второго операнда на место 
первого операнда. Если операнды различаются по типу, то вы¬ 
полняется одно из предусмотренных преобразований. 

Формат. 09, ОА, ОА 

Операнды. Кроме специально оговариваемых случаев, действу¬ 
ют те же правила, что и при выполнении команды MOVE. Од¬ 
нако требования на совместимость операндов менее жесткие. 
В табл. 15.1 представлены все правила выполняемых преобра- 
Таблица 15.1. Правила преобразования 



Обозначения, ц — целое, цур — целое увеличенной разрядности, пч — порядковое чис¬ 
ло, дфт — десятичное с фиксированной точкой, дпт — десятичное с плавающей точкой, 
пс — поле символов, пт — поле токенов, сс — строка символов, ст — строка токенов; 
<Ь> — пробел, <з> — точка в десятичном представлении числа (сокращенно обозначает¬ 
ся символом •) или знак «—», <t> — знак «—» или пробел, <d> — любая цифра в диа¬ 
пазоне 0—9, <е> — любая цифра в диапазоне 1—9, <h> — цифра в диапазоне 0—9 или 
буква от А до F, <Ы» — любой элемент из <h> или <Ь>, квадратные скобки обозна¬ 
чают необязательный элемент, а ... — повторение предыдущего символа. В таблице пред¬ 
ставлены следующие правила преобразования; 
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1. Пересылка данных подобно той, которая выполняется по команде MOVE. 

2. В первый операнд непосредственно пересылаются последние 6, 12 или 2 токен (со¬ 
ответственно для преобразования в целое, целое увеличенной разрядности или порядко¬ 
вое число). Если длина второго операнда больше 6, 12 или 2 токен соответственно, то 
во всех остальных ведущих (левых) токенах должны быть нули. Если второй операнд 
имеет длину меньше 6, 12 или 2 токен соответственно, то он считается дополненным, 
слева нулями до соответствующей длины. 

3. Символьная величина должна иметь одну из следующих форм: 

[<Ь>.„] [<s>] [<b>...] [<d>.„] [•] [<d>...] [<Ь>...] 

[<Ь>...] [<s>] [<Ь>...] L<d>...] [•] [<d>.„] Е [<s>] D... 

4. Целое число преобразуется в одну из следующих форм: 

<t> <e>[<d>...] или <Ъ>0. 

Примечание. Если первый операнд — строка символов, результат выравнивается по ле¬ 
вому концу строки (подобно команде MOVE). Если первый операнд —поле символов, 
результат выравнивается по правому концу строки, а если занимает не всю строку, то 
слева дополняется пробелами. 

5. Десятичное число с фиксированной точкой преобразуется в одну из следующих 

<m> <e>[<d>.„] [•<d>...] или <Ь> 0 [ <d>...] 

См. примечание к правилу 4. 

6. Десятичное число с плавающей точкой приводится к следующему виду: ; 

<m>0-<e>[<d>...] Е <s> <d>. 


См. примечание к правилу 4. 

Число цифр в дробной части равно содержимому поля «размер мантиссы* во втором 

7. Содержимое токенов воспринимается как символьная величина из множества 
<h>. 


8. Целое число воспринимается как содержимое 6, 12 или 2 токен соответственно. 

9. Исходная величина должна состоять из символов множества <hb>. Пробелы пре¬ 
образуются в токены с нулевыми значениями. 


зований. Пробел в таблице означает, что преобразование не вы¬ 
полняется и регистрируется ошибка «несовместимые операнды». 
Если при попытке выполнения преобразования значение второ¬ 
го операнда не удовлетворяет правилам преобразования, регист¬ 
рируется ошибка «недопустимое преобразование данных». В ка¬ 
честве операндов не могут использоваться полностью массивы 
или записи. 

Ошибки. Основной набор ошибок, а также ошибки типа «не¬ 
допустимое преобразование данных» и «переполнение». 

Имя команды. DISPLAY-OPERAND-TYPE (DOT) 

Выполняемая операция. Пересылка тега с атрибутами второго 
операнда в первый операнд. 

Формат. 0008, ОА, ОА 

Операнды. Первый операнд должен быть полем или строкой 
токенов. Второй операнд может быть операндом любого типа, 
кроме литерала. Машина определяет тег второго операнда стан¬ 
дартным образом и помещает копию этого тега в первый опе¬ 
ранд. В частности, если адрес операнда — это адрес ячейки 
«параметр» или «косвенный доступ к данным», в первый опе¬ 
ранд записывается значение вложенного тега. Если же адрес 
операнда указывает на компонент записи или элемент массива, 
записи подлежит значение тега компонента или элемента, а не 
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тега записи или массива. Если адрес операнда — это адрес ячей¬ 
ки, тип которой определяется пользователем, то записывается 
тег этой ячейки. 

Возникновение ошибки «переполнение» блокируется. Если 
длина тега превышает размер первого операнда, последний це¬ 
ликом заполняется токенами из тега, начиная с его начала. 
Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». 

Примечания. Хотя адрес второго операнда может быть адресом 
ячейки любого типа, в основном он используется для обраще¬ 
ния к ячейкам «параметр» или «косвенный доступ к данным» 
с динамически определяемыми типом, границами или размером. 
Использование данной команды позволяет определить текущее 
значение атрибутов ячеек «параметр» или «косвенный доступ 
к данным». 

Имя команды. UNDEFINE (UNDEF) 

Выполняемая операция. Присвоение операнду признака неопре¬ 
деленности его значения. 

Формат. 0001, ОА 

Операнды. Допускаются операнды произвольного типа. Если 
операнд является полем токенов, то данная команда никаких 
операций не выполняет. Если операндом определяется группа 
ячеек (массив, срез массива или запись), неопределенное зна¬ 
чение получает каждый элемент или компонент. 

Ошибки. Основной набор ошибок, за исключением ошибок типа 
«несовместимые операнды». 


АРИФМЕТИЧЕСКИЕ КОМАНДЫ 
Имя команды. ADD 

Выполняемая операция. Сложение двух операндов и запись ре¬ 
зультата на место первого операнда. 

Формат. 2, ОА, ОА 

Операнды. Оба операнда должны быть арифметическими, т. е. 
числами. Оба операнда одновременно могут быть массивами; 
при этом выполняется их поэлементное сложение. Если первый 
операнд — массив, а второй — скалярная величина, значение 
второго операнда добавляется к значениям всех элементов пер¬ 
вого. 

Если операнды отличаются по типу или размеру, второй опе¬ 
ранд преобразуется таким образом, чтобы возможно было вы¬ 
полнение операции сложения, после чего и выполняется эта 
операция. Результат в виде десятичного числа с плавающей 
точкой всегда нормализуется. 
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Ошибки. Основной набор ошибок, а также ошибки типа «пере¬ 
полнение» и «потеря значимости». 

Имя команды. SUBTRACT (SUB) 

Выполняемая операция. Вычитание второго операнда из перво¬ 
го и запись результата на место первого операнда. 

Формат. 3, ОА, ОА 

Операнды. См. описание команды ADD 

Ошибки. Основной набор ошибок, а также ошибки типа «пере¬ 
полнение» и «потеря значимости». 

Имя команды. MULTIPLY (MULT) 

Выполняемая операция. Перемножение двух операндов и запись 
результата на место первого операнда. 

Формат. 4, ОА, ОА 

Операнды. См. описание команды ADD 

Ошибки. Основной набор ошибок, а также ошибки типа «пере¬ 
полнение» и «потеря значимости». 

Примечание. Если операнды являются массивами, то выполня¬ 
ется поэлементное перемножение, а не так называемое матрич¬ 
ное перемножение. 

Имя команды. DIVIDE 

Выполняемая операция. Деление первого операнда на второй 
операнд и запись результата — частного на место первого 
операнда. Если первый операнд — целое число, то результат 
представляется в виде целого числа, величина которого имеет 
максимальное целочисленное значение, не превышающее абсо¬ 
лютной величины частного, а знак совпадает со знаком послед¬ 
него. 

Формат. 02, ОА, ОА 

Операнды. См. описание команды ADD 

Ошибки. Основной набор ошибок, а также ошибки типа «пере^ 
полнение», «потеря значимости» и «некорректное деление». 

Имя команды. REMAINDER 

Выполняемая операция. Деление первого операнда на второй и 
запись остатка на место первого операнда. 

Формат. 0002, ОА, ОА 

Операнды. Операнды могут быть целыми числами, в том числе 
увеличенной разрядности, или порядковыми числами. Оба опе¬ 
ранда могут быть либо массивами, либо скалярами или первый 
операнд может быть массивом, а второй — скаляром. 

Знак результата равен знаку первого операнда. 

Ошибки. Основной набор ошибок, а также ошибки типа «пе¬ 
реполнение» и «некорректное деление». 
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Имя команды. ABSOLUTE (ABS) 

Выполняемая операция. Присвоение операнду положительного 
знака. 

Формат. 01, О А 

Операнды. Операнд может быть любым числом, кроме порядко¬ 
вого. Если операнд — массив чисел, операция выполняется над 
каждым из его элементов. 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». 

Имя команды. COMPLEMENT (COMP) 

Выполняемая операция. Присвоение операнду знака, противо¬ 
положного исходному. 

Формат. ОЕ, ОА 

Операнды. Операнд может быть любым числом, кроме поряд¬ 
кового. Если операнд — массив чисел, то операция выполняется 
над каждым его элементом. 

Ошибки. Основной набор ошибок, за исключением ошибок типа 
«несовместимые операнды». 

КОМАНДЫ СРАВНЕНИЯ И ПЕРЕХОДА 

Имя команды. EQUAL-BRANCH-FALSE (EQBF) 

Выполняемая операция. При равенстве операндов по данной 
команде не выполняется никаких действий; в противном случае 
управление передается по указанному адресу команды. 

Формат. 7, ОА, ОА. ІА 

Операнды. Операнды должны быть взаимно совместимыми (они 
оба могут быть числами, строками символов, логическими ве¬ 
личинами, указателями, полями и строками токенов). 

Если операнды — числа разного типа или размера, то перед их 
сравнением второй операнд преобразуется в форму, совмести¬ 
мую с первым операндом. (Ошибка «переполнение» блокиру¬ 
ется. В случае переполнения операнды считаются не равными 
друг другу.) 

Если операнды — строки и (или) поля разной длины, то пе¬ 
ред их сравнением более короткий операнд дополняется про¬ 
белами (при работе с символьными данными) или нулями (при 
использовании токенов). Эти дополнительные символы для 
строк или полей символов включаются справа, а для строк или 
полей токенов — слева от исходных данных. Массивом может 
быть либо только первый операнд, либо оба операнда. В по¬ 
следнем случае выполняется последовательное сравнение соот¬ 
ветствующих элементов. Если первый операнд — запись, второй 
должен быть записью с аналогичной структурой. При этом 
выполняется сравнение соответствующих компонентов. Операн- 
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ды-массивы (операнды-записи) считаются равными только в 
том случае, если все их соответствующие элементы (компонен¬ 
ты) равны. Для операндов-указателей осуществляется сравне¬ 
ние между собой только логических адресов (сравнение кодов 
доступа не производится). 

Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
верный тип операнда»), а также ошибки типа «недопустимая пе¬ 
редача управления» и «трассировка». 

Имя команды. NOT-EQUAL-BRANCH-FALSE (NEBF) 
Выполняемая операция. Если операнды не равны, никаких дей¬ 
ствий не выполняется; в противном случае управление переда¬ 
ется по указанному адресу команды. 

Формат. 6, ОА, ОА, ІА 

Операнды. См. команду EQUAL-BRANCH-FALSE 
Ошибки. См. команду EQUAL-BRANCH-FALSE 

Имя команды. LESS-THAN-BRANCH-FALSE (LTBF) 
Выполняемая операция. Если первый операнд меньше второго, 
никаких действий не выполняется; в противном случае управ¬ 
ление передается по указанному адресу команды. 

Формат. 8, ОА, ОА, ІА 

Операнды. Операнды могут быть числами, строками или поля¬ 
ми символов, строками или полями токенов. Если операнды — 
разные по типу или размеру числа, то перед их сравнением вто¬ 
рой операнд преобразуется в форму, совместимую с первым опе¬ 
рандом. (Ошибка «переполнение» блокируется. В случае пере¬ 
полнения первый операнд считается меньше второго.) 

Сравнение строк или полей символов производится согласно 
правилам их представления в коде EBCDIC. Строки или поля 
токенов при сравнении рассматриваются как положительные 
шестнадцатеричные числа. Если длины сравниваемых строк 
или полей не совпадают, более короткие из них дополняются 
символами так же, как это делается при выполнении команды 
EQUAL-BRANCH-FALSE. Первый операнд или оба операнда 
могут быть массивами. В последнем случае выполняется их по¬ 
элементное сравнение. При этом первый операнд считается 
меньше второго только в том случае, когда все элементы перво¬ 
го операнда меньше соответствующих элементов второго опе¬ 
ранда. 

Ошибки. Основной набор ошибок, а также ошибки типа «недо¬ 
пустимая передача управления» и «трассировка». 

Имя команды. GREATER-THAN-BRANCH-FALSE (GTBF) 
Выполняемая операция. Если первый операнд больше второго, 



14 ГЛАВА 15 


никаких действий не выполняется; в противном случае управ¬ 
ление передается по указанному адресу команды. 

Формат. 9, ОА, ОА, ІА 

Операнды. См. команду LESS-THAN-BRANCH-FALSE 
Ошибки. См. команду LESS-THAN-BRANCH-FALSE 


Имя команды: LESS-THAN-OR-EQUAL-BRANCH-FALSE 
(LEBF) 

Выполняемая операция. Если первый операнд меньше или ра¬ 
вен второму, никаких действий не выполняется; в противном 
случае управление передается по указанному адресу команды. 
Формат. А, ОА, ОА, ІА 

Операнды. См. команду LESS-THAN-BRANCH-FALSE 
Ошибки. См. команду LESS-THAN-BRANCH-FALSE 


Имя команды. GREATER-THAN-OR-EQUAL-BRANCH-FALSE 
(GEBF) 

Выполняемая операция. Если первый операнд больше или ра¬ 
вен второму, никаких действий не выполняется; в противном 
случае управление передается по указанному адресу команды. 
Формат. В, ОА, ОА, ІА 

Операнды. См. команду LESS-THAN-BRANCH-FALSE 
Ошибки. См. команду LESS-THAN-BRANCH-FALSE 


Имя команды. DEFINED-BRANCH-FALSE (DEFBF) 
Выполняемая операция. Если значение операнда определено, 
никаких действий не выполняется; в противном случае управ¬ 
ление передается по указанному адресу команды. 

Формат. 0004, ОА, ІА 

Операнды. Операнд может быть любого типа. Если операнд — 
поле токенов, никаких действий не выполняется. В случае слож¬ 
ных данных (массива или записи) значение операнда счита¬ 
ется определенным только в том случае, когда заданы значения 
всех элементов. Если операнд — поле символов, его значение 
считается определенным только в том случае, когда задано зна¬ 
чение каждого элемента в этом поле. При использовании в ка¬ 
честве операнда команды указателя его значение считается оп¬ 
ределенным, если в поле его представления отсутствует при¬ 
знак неопределенности и если объект, на который он ссылается, 
еще существует в системе. 

Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операндъ», «неопределенный операнд» и «невер¬ 
ный тип операнда»), а также ошибки типа «недопустимая пере¬ 
дача управления» и «трассировка». 
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Имя команды. ITERATE 

Выполняемая операция. Если первый операнд меньше второго, 
значение первого операнда получает приращение и управление 
передается по указанному адресу команды; в противном случае 
никаких действий не выполняется. 

Формат. 5, ОА, ОА, ІА 

Операнды. Оба операнда должны иметь одинаковый тип и мо¬ 
гут быть целыми числами, в том числе увеличенной разрядно¬ 
сти, а также порядковыми числами. 

Ошибки. Основной набор ошибок, а также ошибки типа «недо¬ 
пустимая передача управления». 

Примечание. Эту команду можно применять для организации 
цикла в качестве его завершающей команды. 


Имя команды. ITERATE-REVERSE (ITERREV) 

Выполняемая операция. Если первый операнд больше второго, 
значение первого операнда уменьшается и управление переда¬ 
ется по указанному адресу команды; в противном случае ника¬ 
ких действий не выполняется. 

Формат. 03, ОА, ОА, ІА 

Операнды. Оба операнда должны иметь одинаковый тип и мо¬ 
гут быть целыми числами, в том числе увеличенной разрядно¬ 
сти, а также порядковыми числами. 

Ошибки. Основной набор ошибок, а также ошибки типа «недо¬ 
пустимая передача управления». 


Имя команды. CASE 

Выполняемая операция. Передача управления по одному из 
указанных адресов команд в зависимости от значения операн¬ 
да, являющегося целым или порядковым числом. 

Формат. 0014, ОА, X, ІА0,...,ІАх 

Операнды. Операнд может быть целым или порядковым чис¬ 
лом. В поле непосредственных данных (X) длиной 2 токен ука¬ 
зывается число от 1 до 255. Это число на единицу меньше чис¬ 
ла возможных адресов команд, задаваемых в команде. Если 
значение операнда попадает в диапазон от 0 до X, управление 
передается команде с адресом ІАі, где і — значение операнда. 
В противном случае управление передается команде с адресом 
ІАх. 

Ошибки. Основной набор ошибок (за исключением ошибок 
«несовместимые операнды»), а также ошибки типа «недопусти¬ 
мая передача управления» и «трассировка». 
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ЛОГИЧЕСКИЕ КОМАНДЫ 
Имя команды. AND 

Выполняемая операция. Логическое умножение (операция И) 
обоих операндов и запись результата на место первого опе¬ 
ранда. 

Формат. 05, ОА, ОА 

Операнды. Операнды должны быть порядковыми числами со 
значениями 0 (ложно) и 1 (истинно). Первый операнд или оба 
операнда могут быть массивами. 

Ошибки. Основной набор ошибок. Если значение порядкового 
числа не равно 0 или 1, регистрируется ошибка «неверный тип 
операнда». 

Имя команды. OR 

Выполняемая операция. Логическое сложение (операция ИЛИ) 
обоих операндов и запись результата на место первого опе- 

Формат. 06, ОА, ОА 
Операнды. См. команду AND 
Ошибки. Основной набор ошибок. 

Имя команды. NOT 

Выполняемая операция. Логическое отрицание (операция НЕ) 
операнда, т. е. изменение его значения на противоположное 
(значение «ложно» заменяется на «истинно», а значение «ис¬ 
тинно» на «ложно»). 

Формат. 0021, О А 

Операнды. Операнд может быть порядковым числом или мас¬ 
сивом таких чисел. 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». 


КОМАНДЫ ПОИСКА И МАНИПУЛИРОВАНИЯ 
СТРОКАМИ СИМВОЛОВ 

Имя команды. CONCATENATE (CONCAT) 

Выполняемая операция. Подсоединение значения второго опе¬ 
ранда к значению первого операнда. 

Формат. 0D, О А, О А 

Операнды. Первый операнд должен быть строкой и не может 
иметь неопределенного значения. Второй операнд должен быть 
строкой или полем того же типа. Длина первого операнда уве¬ 
личивается на длину второго операнда, а значение второго опе¬ 
ранда подсоединяется к концу первого операнда. 
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Ошибки. Основной набор ошибок, а также ошибки типа «пере¬ 
полнение». 

Имя команды. MOVE-SUBSTRING (MOVESS) 

Выполняемая операция. Часть строки или поля (подстрока),, 
указываемая второй группой операндов, пересылается в подт 
строку, указываемую первой группой операндов. 

Формат. 04, ОА, ОА, ОА, ОА, ОА, ОА 

Операнды. Первый и четвертый операнды должны быть строка¬ 
ми или полями, причем совместимыми (оба операнда должны 
содержать либо символы, либо токены). Второй, третий, пятый 
и шестой операнды должны быть целыми числами. Операнды 
с первого по третий определяют подстроку, принимающую дан¬ 
ные. Аналогично операнды с четвертого по шестой определяют 
подстроку, посылающую данные. Второй операнд задает по¬ 
рядковый номер элемента, с которого начинается подстрока, 
а значение третьего операнда равно ее длине. 

Если первый операнд является строкой, а не полем и L — 
ее текущая длина, то значение второго операнда должно быть 
большим или равным 1 и меньшим или равным L+1. В резуль¬ 
тате выполнения операции длина строки может увеличиваться. 
Если первый операнд является строкой с неопределенным зна¬ 
чением, значение второго операнда должно равняться 1. 

Если значение третьего операнда больше значения шестого- 
операнда (принимающая подстрока длиннее посылающей под¬ 
строки), происходит заполнение избыточной части подстроки 
одним из дополнительных символов. Для подстрок символов это 
дополнительное заполнение выполняется справа пробелами, а 
для подстрок токенов — слева нулями. Указанное заполнение 
имеет место только в пределах подстроки-результата, а не во 
всей принимающей строке или поле. 

Если обе подстроки принадлежат одной и той же строке 
или полю и взаимно перекрываются, результат соответствует 
таким действиям, при которых посылаемая подстрока сначала 
извлекается из того места, где находится, а затем помещается 
в принимающую подстроку. 

Ошибки. Основной набор ошибок, а также ошибки типа «пере¬ 
полнение». 

Имя команды. INDEX 

Выполняемая операция. Начиная с указанной позиции по строке 
или полю, выполняется поиск заданной подстроки. Если подст¬ 
рока будет найдена, первый операнд будет содержать индекс 
(порядковый номер) первого элемента этой подстроки в строке 
или поле. Если подстрока обнаружена не будет, значение пер¬ 
вого операнда полагается равным 0. 


2-429 



18 ГЛАВА IS 


Формат. 07, ОА, ОА, ОА, ОА 

Операнды. Первый операнд должен быть целым числом. Перед 
началом выполнения команды его значением является порядко¬ 
вый номер элемента в строке, с которого должен быть начат 
поиск. Второй операнд также должен быть целым числом. Ес¬ 
ли он имеет ненулевое значение, оно определяет порядковый 
номер элемента в строке, где поиск должен быть прекращен. 
Если его значение равно 0, поиск будет проводиться до конца 
строки. Третий операнд задает строку или поле, где произво¬ 
дится поиск. Четвертый операнд должен быть строкой или по¬ 
лем и иметь тот же тип (т. е. быть строкой или полем симво¬ 
лов, логических величин или токенов), что и третий операнд. 
Четвертый операнд — это подстрока, местоположение копии ко¬ 
торой в третьем операнде подлежит обнаружению. 

Ошибки. Основной набор ошибок. В нижеследующих случаях 
регистрируется ошибка «выход индекса за допустимые границы»: 
1) порядковый номер элемента, с которого должен быть начат 
поиск, меньше 1; 2) порядковый номер элемента, где поиск 
должен быть прекращен, отрицательный; 3) сумма значений 
порядкового номера элемента, где поиск должен быть начат 
или закончен, и длины подстроки, местоположение которой оп¬ 
ределяется, превышает увеличенную на 1 длину (размер) стро¬ 
ки (поля), в которой ведется поиск. 

Имя команды. LENGTH 

Выполняемая операция. Значение длины второго операнда 
(строки или поля) присваивается первому операнду. 

Формат. 08, ОА, ОА 

Операнды. Первый операнд должен быть целым числом, а вто¬ 
рой — строкой или полем. 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды» и «неопределенный операнд». 

Имя команды. SEARCH 

Выполняемая операция. В команде задаются массив (или срез 
массива), значение индекса, точка окончания и значение клю¬ 
ча для поиска. Выполняется поиск заданного значения ключа 
среди всех элементов массива, начиная с элемента с указанным 
индексом. При обнаружении такого элемента его индекс при¬ 
сваивается операнду, в котором первоначально указывается ис¬ 
ходное значение индекса. Если элемент обнаружить не удается, 
упомянутому операнду присваивается нулевое значение. 
Формат. 0003, ОА, ОА, ОА, ОА 

Операнды. Первый операнд должен быть целым числом. Пер¬ 
воначально в нем содержится значение индекса элемента, с ко¬ 
торого следует начинать поиск. По окончании операции в нем 
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располагается порядковый номер элемента, значение которого 
совпадает с заданным ключевым (или равно 0). Второй опе¬ 
ранд должен быть целым числом. Если оно не равно 0, то яв¬ 
ляется индексом того элемента в массиве, на котором поиск 
должен быть закончен. Если его значение равно 0, поиск ведет¬ 
ся до последнего элемента массива. Третий операнд должен 
быть одномерным массивом или срезом (адрес операнда зада¬ 
ется в форме адреса массива или среза). Четвертый операнд 
содержит ключ — значение, поиск которого проводится. Эле¬ 
менты массива сравниваются с ключевым значением по прави¬ 
лам, описанным для команды EQBF. 

Ошибки. Основной набор ошибок. 

КОМАНДЫ УПРАВЛЕНИЯ 
Имя команды. CALL 

Выполняемая операция. Прерывание выполнения данного моду¬ 
ля и инициирование выполнения другого модуля с заданной 
точки входа. Для вызываемого модуля выполняются выделение 
и начальная установка памяти для динамической части адрес¬ 
ного пространства. 

Формат. D, ОА, X, А1, ОА1,...,Ах, ОАх 

Операнды. Первый операнд — указатель на точку входа моду¬ 
ля (должен содержать разрешение на чтение). Значение ука¬ 
зателя должно предварительно формироваться с помощью 
команды CREATE-ENTRY-CAPABILITY. Поле непосредственных 
данных имеет длину 2 токен и содержит шестнадцатеричное 
число X, равное количеству передаваемых фактических пара¬ 
метров. X пар полей, следующих за этими двумя токенами, ха¬ 
рактеризуют отдельные параметры. Аі является непосредствен¬ 
ным адресом (длиной 1 токен), значение которого определяет, 
передается ли фактический параметр с разрешением как чте¬ 
ния, так и записи (значение = 0011) или только чтения (зна- 
чение = 0111). ОАі обозначает адрес фактического параметра в 
форме адреса операнда. Фактическими параметрами не могут 
быть литералы или срезы, а также адреса ячеек «косвенный 
доступ к данным». 

Ошибки. Основной набор ошибок, а также ошибки типа «трас¬ 
сировка команды CALL», «недопустимая передача управления» 
и «недостаточный объем памяти». Если в программе обработ¬ 
ки ошибок встречается команда CALL и существуют области 
активации, подчиненные текущей области (образованные после 
данной области), все они ликвидируются. 

Примечания. При выполнении команды CALL действительной 
передачи фактических параметров, соответствующих формаль¬ 
ным параметрам вызываемого модуля, не происходит. Эта 


2* 
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операция выполняется по команде ACTIVATE при вызываемой 
точке входа. По команде CALL создается запись активации, 
помещаемая как последняя запись в стек записей активации 
данного процесса. 


Имя команды. ACTIVATE (ACT) 

Выполняемая операция. Проверка формальных и фактических 
параметров на соответствие друг другу и присвоение началь¬ 
ных значений указанным формальным параметрам. 

•Формат. С, X, СА1,...,САх 

Операнды. В поле непосредственных данных (длиной 2 токен) 
в шестнадцатеричной форме задается количество параметров 
(X). Следующие за этим полем X полей являются адресами 
ячеек «параметр». Этим формальным параметрам присваивают¬ 
ся значения фактических параметров, переданные последней 
выполнявшейся в данной процесс-машине командой CALL или 
LCALL. 

Ошибки. Имеют место ошибки «неправильная адресация», «дан¬ 
ные неизвестного формата», «имитация ошибки», «неверный 
тип операнда», «неправильное число передаваемых данных», 
«несовместимые операнды». 

Примечания. Правила совместимости формальных и фактиче¬ 
ских параметров приведены в табл. 15.2. Команда ACTIVATE 
не обязательно должна быть первой командой у заданной точки 
входа в модуль, но она должна предшествовать любому обра¬ 
щению к ячейкам «параметр». (В противном случае параметр 
<5удет иметь неопределенное значение.) Если команда 
ACTIVATE подлежит включению в группу команд, связанных 
с вызовом модуля, она должна предшествовать любой команде, 
определяющей фактические параметры (CALL, LCALL, SEND, 
RECEIVE). 


Имя команды. RETURN 

Выполняемая операция. Завершение выполнения данного моду¬ 
ля и передача управления команде, следующей за командой 
CALL, которая вызывает данный модуль. 

Формат. ОА 
Операнды. Отсутствуют. 

Ошибки. Имеют место ошибки типа «имитация ошибки». 
Примечания. Команда RETURN отменяет режим, установлен¬ 
ный предыдущими командами CALL и ACTIVATE, т. е. унич¬ 
тожает текущую запись активации. Если это была единствен¬ 
ная запись активации, то уничтожается и данная процесс-ма¬ 
шина. 
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Таблица 15.2. Правила соответствия между формальными 
и фактическими параметрами 


Формальный параметр 


Фактический параметр 


Параметр с динамически 
определяемым типом 
Целое число, указатель, 
целое число увеличен¬ 
ной разрядности, по¬ 
рядковое число 
Десятичное число с фик¬ 
сированной или плава¬ 
ющей точкой, логиче¬ 
ская величина, поле 
(строка) символов или 
токенов 
Запись 


Массив 


Параметр, тип которого 
определяется пользо¬ 
вателем 


Любая ячейка простого типа, кроме ячейки, тип 
которой определяется пользователем 
По типу идентичный формальному параметру 


По типу идентичный формальному параметру; 
должна быть идентичность и по размеру, за 
исключением тех случаев, когда формальный 
параметр имеет динамически определяемый раз¬ 
мер 

Запись с таким же числом компонентов. Тип и 
размер каждого компонента должны совпадать 
с типом и размером соответствующих компо¬ 
нентов записи — формального параметра. Если 
компонентами записи являются массивы, у них 
должна быть такая же размерность, как и у 
соответствующих массивов-компонентов в запи¬ 
си — формальном параметре, и идентичные атри¬ 
буты элементов. Они должны также иметь оди¬ 
наковые верхние границы для индексов, если 
только массивы в записи — формальном пара¬ 
метре не являются массивами с динамическим 
определением границ 

Массив такой же размерности. Если массив — 
формальный параметр не является массивом с 
динамическим определением границ, последние 
должны быть идентичными для обоих масси¬ 
вов. Типы элементов в обоих массивах также 
должны быть назначены одинаковыми, если 
только массив — формальный параметр не яв¬ 
ляется массивом с динамическим определением 
типа. То же относится и к их атрибуту «раз¬ 
мер» 

Аналогичные атрибуты пользователя, а также 
совместимость по вышеприведенным правилам 
для ячеек, определяемых формальными и фак¬ 
тическими параметрами 


Имя команды. LOCAL-CALL (LCALL) 

Выполняемая операция. Приостановка последовательного вы¬ 
полнения команд и передача управления указываемой команде 
в данном модуле. 

Формат. 000В, ІА, X, А1, ОА1.Ах, О Ах 

Операнды. В первом поле адреса задается адрес команды, ко¬ 
торой передается управление. Остальные поля —такие же, как 
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и в команде CALL. Передаваемые фактические параметры не 
могут быть литералами или косвенными указателями. 

Ошибки. Основной набор ошибок, а также ошибки типа «недо¬ 
пустимая передача управления», «трассировка команды CALL» 
и «недостаточный объем памяти». 

Примечания. В отличие от команды CALL команда LCALL не 
создает записи активации. Следовательно, внутренние процеду¬ 
ры не допускают рекурсивного обращения (если только ком¬ 
пилятор не генерирует команду ALLOCATE в целях имитации 
наличия записи активации); согласование всех имен возлагает¬ 
ся на компилятор. 

Имя команды. LOCAL-RETURN (LRETURN) 

Выполняемая операция. Передача управления команде, следую¬ 
щей за последней выполнявшейся в данном модуле командой 
LCALL. 

Формат. 000С 
Операнды. Отсутствуют. 

Ошибки. Имеют место ошибки типа «недопустимая передача 
управления» (если не было предшествующей команды LCALL) 
и «имитация ошибки». 

Примечания. Если команда LRETURN встречается в програм¬ 
ме обработки ошибок, а в модуле отсутствует команда LCALL, 
выполнение программы обработки ошибок прекращается и 
управление передается команде, при выполнении которой про¬ 
изошла регистрация ошибки 1 ). 

Имя команды. BRANCH (В) 

Выполняемая операция. Передача управления по указанному 
адресу команды. 

Формат. Е, ІА 

Ошибки. Имеют место ошибки типа «недопустимая передача 
управления» и «имитация ошибки». 

КОМАНДЫ АДРЕСАЦИИ 

Имя команды. COMPUTE-CAPABILITY (ССАР) 

Выполняемая операция. Запись потенциального адреса второго 
операнда на место первого операнда. 

Формат. 0010, О А, ОА 

Операнды. Первый операнд должен быть указателем. Второй 
операнд может быть любым, кроме ячейки «параметр» литера¬ 
ла или всего среза. В коде доступа потенциального адреса 


11 Или следующей за ней команде, если она была командой RAISE- 
FAULT. — Прим, перев. 
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устанавливаются разрешение на копирование и запрет на унич¬ 
тожение. Разрешение на чтение-запись задается в соответст¬ 
вии с текущим кодом доступа данного модуля ко второму 
операнду. 

Потенциальный адрес является адресом ячейки 1 ), указывае¬ 
мой вторым операндом. Если такая ячейка — «косвенный доступ 
к данным», то на место первого операнда записывается указа¬ 
тель, соответствующий этой ячейке. При этом код доступа ука¬ 
зателя должен содержать разрешение на копирование. 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «неопределенный операнд» и «несовместимые операнды». 

Имя команды. COMPUTE-INDIRECT-CAPABILITY (СІСАР) 
Выполняемая операция. Запись косвенного потенциального ад¬ 
реса второго операнда на место первого операнда. 

Формат. 0016, ОА, О А 

Операнды. Оба операнда должны быть указателями. Первый 
операнд становится косвенным потенциальным адресом второго 
операнда. Его код доступа дублирует код доступа второго опе¬ 
ранда. В коде доступа второго операнда должно быть разре¬ 
шение на копирование, а сам операнд не может быть косвен¬ 
ным потенциальным адресом или параметром. 

Ошибки. Основной набор ошибок, за исключением ошибок типа 
«несовместимые операнды» и «неопределенный операнд». 

Имя команды. COMPUTE-CAPABILITY-EXTERNALLY 
(ССАРЕХ): 

Выполняемая операция. Запись на место первого операнда по¬ 
тенциального адреса операнда, к которому имеет место внеш¬ 
няя адресация с помощью второго, третьего и четвертого опе¬ 
рандов (адресация к операнду называется внешней, поскольку 
он принадлежит другому адресному пространству заданного 
модуля данной процесс-машины). 

Формат. 0012, О А, О А, О А, О А 

Операнды. Первые три операнда должны быть указателями. 
Второй операнд представляет собой потенциальный адрес про¬ 
цесс-машины. Третий операнд является потенциальным адресом 
объекта «модуль». Четвертый операнд должен быть строкой или 
полем токенов. Он выполняет такую же роль, как адрес вто¬ 
рого операнда в команде COMPUTE-CAPABILITY. Этот опе¬ 
ранд [в форме адреса ячейки, массива (среза), элемента мас- 


11 Логическим или системным адресом ячейки в отличие от адреса ячейки 
как разновидности адреса операндов, используемого в командах. — Прим, 
перев. 
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сива (среза), записи или компонента записи] используется как. 
адрес операнда, входящего в модуль, на который ссылается тре¬ 
тий операнд. 

Коды доступа, которые следует задать в исходных потенци¬ 
альных адресах, и код доступа, который будет получен с ре¬ 
зультирующим потенциальным адресом, зависят как от того,, 
принадлежит ли операнд динамической или статической части 
адресного пространства адресуемого модуля, так и от того, яв¬ 
ляется ли он косвенным доступом к данным. Возможны следу¬ 
ющие варианты: 

1. Операнд относится к статической части адресного прост¬ 
ранства и не является косвенным доступом к данным. В этомі 
случае система не пользуется потенциальным адресом процесс- 
машины и никаких специальных требований к коду доступа по¬ 
тенциального адреса не предъявляется. Код доступа потенци¬ 
ального адреса-результата содержит разрешение на копирова¬ 
ние и запрет на уничтожение. Разрешение на чтение-запись в 
коде доступа результата устанавливается в соответствии с ди¬ 
рективной информацией в коде доступа потенциального адре¬ 
са модуля. 

2. Операнд относится к динамической части адресного про¬ 
странства и не является косвенным доступом к данным. Отсут¬ 
ствуют какие-либо специальные требования к кодам доступа 
потенциальных адресов как процесс-машины, так и модуля. 
Код доступа потенциального адреса-результата содержит раз¬ 
решение на копирование и запрет на уничтожение. Разрешение 
на чтение-запись в коде доступа результата устанавливается в 
соответствии с директивной информацией в коде доступа по¬ 
тенциального адреса модуля. 

3. Операнд является косвенным доступом к данным и отно¬ 
сится к статической части адресного пространства. В этом слу¬ 
чае система также не пользуется потенциальным адресом про¬ 
цесс-машины. Потенциальный адрес модуля должен содержать 
разрешение только на чтение, а указатель, соответствующий 
ячейке «косвенный доступ к данным», — разрешение на копиро¬ 
вание. Содержимое этого указателя определяет значение потен¬ 
циального адреса результата. 

4. Операнд является косвенным доступом к данным и отно¬ 
сится к динамической части адресного пространства. Потен¬ 
циальный адрес процесс-машины должен содержать разрешение 
только на чтение, а потенциальный адрес указателя — разреше¬ 
ние на копирование. Код доступа в потенциальном адресе мо¬ 
дуля не нуждается в задании какой-либо специальной дирек¬ 
тивной информации. В ячейку результата помещается содер¬ 
жимое указателя, соответствующего ячейке «косвенный доступ 
к данным». 
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Если операнд или указатель, соответствующий ячейке «кос¬ 
венный доступ к данным», которая выполняет роль операнда, 
принадлежит динамической части адресного пространства, ре¬ 
зультат определяется текущим (последним) обращением к это¬ 
му модулю при работе указанной процесс-машины. 

■Ошибки. Основной набор ошибок. 

Примечания. В семантическом отношении выполнение команды 
ССАРЕХ полностью эквивалентно выполнению команды ССАР 
і в заданном модуле указанной процесс-машиной. Команда 
ССАРЕХ разрабатывалась для создания средств отладки, с по¬ 
мощью которых можно было бы производить обращение к дан¬ 
ным отлаживаемой программы. 

Хотя в последнем операнде команды адрес операнда пред¬ 
ставляет собой обращение к адресному пространству другого 
модуля, длина этого адреса должна соответствовать величине 
■CAS в модуле, содержащем данную команду ССАРЕХ. Коман¬ 
да ССАРЕХ может использоваться совместно с командой DOT 
для определения текущих атрибутов данных из другого модуля. 
В таком случае указатель, в который будет загружаться ре¬ 
зультат, должен соответствовать ячейке «косвенный доступ к 
данным» с динамически определяемым типом; последняя долж¬ 
на являться операндом команды DOT. Если атрибуты ячейки, 
потенциальный адрес которой определяется, неизвестны, в чет¬ 
вертом операнде команды ССАРЕХ должна быть использована 
•форма адресации, которую следовало бы применить для масси¬ 
ва, имеющего размерность 15. 

Имя команды. CHANGE-ACCESS (САСС) 

Выполняемая операция. Установление дополнительных ограни¬ 
чений в коде доступа указываемого операнда (изменение зна¬ 
чения кода на новое значение, задаваемое в команде). 

■Формат. 0006, X, ОА 

Операнды. Операнд должен быть указателем. Поле непосред¬ 
ственных данных (X) имеет длину 1 токен. Новое значение ко¬ 
да доступа формируется в результате выполнения логической 
операции ИЛИ над старым значением кода доступа и вели¬ 
чиной X. Так вводится специальная директивная информация 
(дополнительные ограничения) в код доступа указателя. 
Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». 

Имя команды. ALLOCATE (ALLOC) 

Выполняемая операция. Создание объекта «память данных» с 
описанием возможного содержимого, задаваемого операндом 
команды. 
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Формат. 0020, X, ОА 

Операнды. В последнем разряде поля непосредственных дан¬ 
ных (X) длиной 1 токен указывается, должен ли данный объект 
автоматически ликвидироваться при уничтожении процесс-ма¬ 
шины, выполняющей в данный момент эту команду. Значение 
хххО является требованием на уничтожение. 

В третьем разряде этого поля указывается, должно ли при¬ 
сваиваться выделенной памяти в качестве начального неопре¬ 
деленное значение. Требованию такой начальной установки со¬ 
ответствует содержимое поля, равное ххОх; содержимое ххіх 
означает отсутствие этого требования. Если требование на¬ 
чальной установки отсутствует, а создаваемый объект должен 
содержать ячейки «указатели», отсутствие этого требования 
игнорируется и всем указателям присваивается неопределенное 
значение. 

Адрес операнда должен быть адресом ячейки, элемента мас¬ 
сива, массива или записи. Операнд должен быть ячейкой «кос¬ 
венный доступ к данным», которая может содержать описание 
ячейки любого типа. Косвенный доступ к данным не может рас¬ 
полагать атрибутами, обеспечивающими динамическое опреде¬ 
ление размера или типа. 

Если операндом является массив, ссылка к которому дела¬ 
ется в форме адреса массива, содержимое полей верхней гра¬ 
ницы значения индекса по соответствующей размерности мас¬ 
сива используется для определения размера массива. Если же 
адресация к массиву задается посредством адреса элемента 
массива, содержимое полей верхней границы значения индекса 
по соответствующей размерности массива в его теге должно 
равняться 0 (т. е. массив должен иметь динамически определяе¬ 
мые границы). В этом случае текущие значения индексов счи¬ 
таются верхними значениями индексов при выделении памяти 
под массив. 

Описание возможных ячеек создаваемого объекта содержит¬ 
ся во вложенном теге (включающем соответствующие теги). 
Код доступа в указателе, задаваемом соответствующей ячейкой 
«косвенный доступ к данным», имеет значение 0000 (т. е. санк¬ 
ционированы чтение, запись, уничтожение и копирование), а ло¬ 
гический адрес в нем ссылается на генерируемый объект «па¬ 
мять данных». 

Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операнды»), а также ошибки типа «недостаточ¬ 
ный объем памяти». 

Примечание. Учитывая особенности архитектуры, при выполне¬ 
нии команды ALLOCATE рекомендуется задавать ее необяза¬ 
тельный параметр «присвоение неопределенного значения в ка¬ 
честве начального». Возможность использования этого парамет- 
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ра как необязательного была введена для удобства разработки 
программ компиляторов, в которых после команды ALLOCATE 
предполагается выполнение начальной установки программным 
путем. 

Имя команды. DESTROY 

Выполняемая операция. Уничтожение объекта, адресуемого опе¬ 
рандом. 

Формат. 0007, ОА 

Операнды. Операнд должен быть указателем, косвенным до¬ 
ступом к данным или параметром-указателем. По данной 
команде выполняется ликвидация объекта, адресуемого указа¬ 
телем-операндом (или указателем, соответствующим ячейке 
«косвенный доступ к данным»). Кодом доступа указателя долж¬ 
на быть санкционирована возможность уничтожения объекта. 
После выполнения операции в указатель записывается признак 
неопределенного значения. Если команда DESTROY относится 
к модулю, находящемуся в активном состоянии (для которого 
существует область активации), немедленно выполняется унич¬ 
тожение системного имени этого модуля как объекта (что озна¬ 
чает невозможность дальнейших обращений к нему, например 
посредством команды CALL). Однако сам объект будет выве¬ 
ден из системы лишь после того, как прекратят существование 
все его записи активации. Если уничтожению подлежит объект 
«порт» с ожидающими обработки запросами команд SEND или 
RECEIVE, порт уничтожается, а выполнение указанных «по¬ 
висших» команд прерывается с регистрацией ошибки «недей¬ 
ствительный указатель» 1 ). 

Если объектом команды DESTROY является процесс-маши¬ 
на, содержащая объекты с признаком их ликвидации косвен¬ 
ным путем при уничтожении этой процесс-машины, эти объек¬ 
ты уничтожаются вместе с процесс-машиной. (См. описание 
передачи AM в гл. 9.) 

Требование уничтожения объекта «память данных» также 
может выполняться с задержкой, предусмотренной для того, 
чтобы система не уничтожила объект в момент обращения к 
нему команды из другой процесс-машины. 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». . 

Имя команды. CHANGE-LOGICAL-ADDRESS (GLA) 
Выполняемая операция. Присвоение указанному объекту ново- 


■> По-видимому, разновидность состояния «недействительный потенциаль¬ 
ный адрес». — Прим, перев. 
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го логического адреса и уничтожение его старого логического 
адреса. 

Формат. 0022, ОА 

Операнды. Операндом должна быть ячейка «указатель» или 
«косвенный доступ к данным». Код доступа в указателе дол¬ 
жен содержать директивную информацию, санкционирующую 
чтение, запись, копирование и уничтожение. При этом указа¬ 
тель должен ссылаться на весь объект, а не на какую-либо его 
часть. В результате выполнения команды объекту, на который 
ссылается указатель, назначается новый логический адрес, по¬ 
мещаемый в тот же указатель с кодом доступа, санкциониру¬ 
ющим выполнение перечисленных операций. Любая последую¬ 
щая попытка воспользоваться старым логическим адресом объ¬ 
екта приводит к регистрации ошибки «недействительный ука¬ 
затель». 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». 


Имя команды. CREATE-MODULE (CMODULE) 

Выполняемая операция. Создание объекта «модуль». 

Формат. 0009, X, ОА, ОА 

Операнды. Содержимое поля непосредственных данных (X) 
длиной 1 токен показывает, должен ли объект «модуль» авто¬ 
матически ликвидироваться при уничтожении процесс-машины, 
в которой выполняется эта команда. В частности, если содер¬ 
жимое этого поля равно хххО, то требуется ликвидация модуля 
при уничтожении процесса. Порядок уничтожения модуля при¬ 
водится в описании команды DESTROY. 

Первый операнд должен быть указателем, а второй — стро¬ 
кой или полем токенов. Содержимое этого поля или строки 
должно соответствовать формату внешнего модуля (см. 
рис. 14.3). Машина проверяет правильность формата модуля, 
копирует его во внутреннюю память и загружает в указатель 
потенциальный адрес объекта «модуль» с полным набором 
санкционированных возможностей доступа (чтение, запись, 
уничтожение и копирование). Для всех параметров и указате¬ 
лей в модуле устанавливается признак неопределенного значе¬ 
ния. В рамках сформированного объекта «модуль» выделяется 
память для массивов, описываемых в статической части адрес¬ 
ного пространства. 

Ошибки. Основной набор ошибок (за исключением ошибок ти¬ 
па «несовместимые операнды»), а также ошибки «недействи¬ 
тельный модуль» и «недостаточный объем памяти». При регист¬ 
рации ошибки «недействительный модуль» пятый фактический 
параметр, передаваемый программе обработки ошибок при его 
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вызове, содержит информацию о характере ошибки. Этот пара¬ 
метр может иметь следующие значения: 

000001 —ошибка в указателях в заголовке модуля; 

000002 — недопустимые значения в полях GAS; IAS или SlSy. 
ссссОЗ — недопустимая к использованию ячейка или непра¬ 
вильная связь ячеек в модуле; 

ІІН04 — адрес операнда в некоторой команде не соответству¬ 
ет началу ячейки или ее компонента. 

Здесь сссс — четыре младших токена адреса ячейки, в которой 
обнаружена ошибка; іііі — четыре младших токена адреса не¬ 
правильной команды. 

Имя команды. COMPUTE-ENTRY-CAPABILITY (СЕСАР)' 
Выполняемая операция. Вычисление потенциального адреса 
для указываемой команды в заданном, модуле. 

Формат. 0O0F, ОА, ОА, ОА 

Операнды. Первый операнд является указателем, используемым 
для размещения результата. Второй операнд — указатель тре¬ 
буемого объекта «модуль». Третий операнд представляет со¬ 
бой поле длиной 5 токен, где задается адрес команды модуля, 
для которой необходимо вычислить потенциальный адрес. Этот 
адрес помещается в первый операнд. Код доступа санкциониру¬ 
ет чтение и копирование. 

Ошибки. Основной набор ошибок, за исключением ошибок типа 
«несовместимые операнды». Ошибка «неправильная адресация»- 
регистрируется в тех случаях, когда адрес команды выходит 
за пределы области команд. Ошибка «нарушение защиты досту¬ 
па» регистрируется тогда, когда кодом доступа во втором опе¬ 
ранде не предусмотрены возможности чтения или копирования. 

Имя команды. LINK 

Выполняемая операция. Присвоение потенциального адреса. 
Формат. О00А, ОА, ОА, ОА 

Операнды. Первый операнд является указателем объекта «мо¬ 
дуль». В указателе должна быть предусмотрена возможность 
записи. Второй операнд есть поле из 5 токен. В этом поле 
задается адрес ячейки, принадлежащий статической части ад¬ 
ресного пространства модуля. Третий операнд является указа¬ 
телем. Значение этого указателя присваивается указателю, оп¬ 
ределяемому первым и вторым операндами. 

Ошибки. Основной набор ошибок, за исключением ошибок типа- 
«несовместимые операнды». Если ячейка для размещения ре¬ 
зультата находится в статической части адресного пространства* 
или не является указателем, то регистрируется ошибка «не¬ 
правильная адресация». 
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Имя команды. DESCRIBE-CAPABILITY 

Выполняемая операция. Определение по заданному указателю 
его значения и данных об адресуемой им ячейке. 

Формат. 001В, ОА, ОА, ОА, ОА, ОА 

Операнды. Первые два операнда должны иметь целочисленные 
значения. Третий операнд — указатель. Четвертый операнд — 
одномерный массив полей символов размера 6. (Адрес операн¬ 
да должен быть представлен в форме адреса массива.) Массив 
должен состоять по крайней мере из трех элементов. Пятый 
операнд является указателем, по которому должна быть полу¬ 
чена информация. 

По данной команде в первых трех операндах записывается 
информация о значении указателя и адресуемой им ячейке. 
Информация, получаемая при выполнении команды, представ¬ 
лена в табл. 15.3, где ОА4(і) —значение і-го элемента четвер¬ 
того операнда. 

Ошибки. Основной набор ошибок. 


Таблица 15.3. Результаты выполнения команды DESCRIBE-CAPABILITY 




Тип информации в 

ячейках, адресуемых 






четвертым операндом 

мый указателем 

операндом 

операндом 

ОА2 

операндом 

ОАЗ 

ОА4 (1) 

ОА4 (2) 

ОА4 (3) 

Модуль 

1 

15 

16 

6 

7 

8 

Порт 

1 

2 

16 

6 

7 

9 

Память данных 

1 

5 

16 

6 

7 

10 

Процесс-машина 

13 

14 

16 

6 

7 

11 

Ячейка в статиче¬ 
ской части ад¬ 
ресного прост¬ 
ранства модуля 

3 

5 

17 

6 

7 

12 

Ячейка в записи 
активации 

3 

5 

17 

6 

7 

12 

Ячейка в памяти 
данных 

3 

5 

17 

6 

7 

12 

Точка входа в мо¬ 
дуль 

4 

5 

17 

6 

7 

12 

Внешний порт 

5 

5 

5 

6 

7 

12 


Примечание. В таблице использованы следующие обозначения: 

1 — размер объекта (в единицах AM) ; 

2 — количество процесс-машин, находящихся в данный момент в очереди к порту: 

3 —тип ячейки (значение первых четырех двоичных разрядов тега); 

4 — адрес точки входа в форме адреса команды; 

В — неопределенное значение; 

6 — директивная информация о видах доступа, предоставленного данному указателю- 
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Номер символа 

Значение символа 

1 

2 

3 

4 

5 

6 

Пробел или R (чтение) 

Пробел или W (запись) 

Пробел или D (уничтожение) 

Пробел или С (копирование) 

Тип указателя: пробел (прямой указатель) или I (кос* 
венный указатель) 

Пробел 

гласно следующим 
МО — объект «мод 
РО — объект «пор 
DO — объект «пам 
ХО — процесс-маш 
МС — ячейка в ст 
АС — ячейка в заі 
DC — ячейка в па 

обозначениям: 

ять данных»; 

тической части адресного пространства модуля; 
иси активации; 
мяти данных; 

ЕО — внешний іюі 
Символы с 3-го ПС 
8 — состояние модуля: 

6-й являются пробелами: 

Номер символа 

Значение символа 

1 

2 

3 

4 

5-6 

9 — состояние порта: 

Пробел или Р (подлежит ликвидации при уничтожении 
процесс-машины) 

Пробел или А (в активном состоянии) 

Пробел или G (в состоянии «охраняем») 

Пробел или Т (выполняется трассировка) 

Пробелы 

Номер символа 

Значение символа 

1 

2 

3-6 

10 — состояние памяти 

Пробел или Р (подлежит ликвидации при уничтожении 
процесс-машины) 

Пробел, или S (невыполненная передача), или R (не¬ 
выполненный прием) 

Пробелы 

данных: 

Номер символа 

Значение символа 

1 

2-6 

Пробел или Р (подлежит ликвидации при уничтожении 
процесс-машины) 

Пробелы 
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11 — состояние процесс-машины: 


Номер символа 

Значение символа 

1 

Пробел или Р (подлежит ликвидации при уничтожении 
процесс-машины) 

2 

Состояние машины: 

А (активна) 

В (заблокирована по команде GUARD) 

Р (ожидает обмена с портом) 

D (приостановлена по команде DELAY) 

S (остановлена/ожидает перехода в это состояние) 

X (ожидает обмена с внешним портом) 

3-6 

Пробелы 


13 — размер’ свободной памяти (в единицах AM), которой в данный момент располагает 
процесс-машина; 


tlo — количество процесс-машин,’ блокируемых модулем, находящимся в состоянии «охра- 

16 — потенциальный адрес процесс-машины, создавшей данный объект, при условии, что 

последний подлежит автоматическому уничтожению с уничтожением процесс-маши¬ 
ны; иначе — неопределенное значение. В коде доступа потенциального адреса имеет¬ 
ся разрешение только на копирование; 

17 —потенциальный адрес того объекта (модуля и памяти данных), которому принадле¬ 

жит адресуемый элемент. Если адресуется ячейка из записи активации, выдается 
потенциальный адрес соответствующего модуля; в коде доступа этого адреса имеет¬ 

ся разрешение только на копирование. 


.'КОМАНДЫ УПРАВЛЕНИЯ 
«ПРОЦЕСС-МАШИНАМИ 

Имя команды. CREATE-PROCESS-MACHINE (CMACHINE) 
Выполняемая операция. Создание процесс-машины и передача 
-ей имеющейся в наличии памяти (измеряемой количеством 
AM) от текущей процесс-машины. Работа новой процесс-маши¬ 
ны начинается с определенной точки входа указываемого мо¬ 
дуля, для данных которого, описанных в динамической части 
-его адресного пространства, осуществляется выделение памяти 
с последующим присвоением ей начальных значений. 

* Формат. 00 ІА, X, О А, О А, О А, О А 

Операнды. Содержимое поля непосредственных данных (X) 
длиной 1 токен указывает, должна ли новая процесс-машина ав¬ 
томатически уничтожаться при ликвидации процесс-машины, 
•в которой выполняется данная команда. В частности, значение 
хххО указывает на необходимость уничтожения. 

Первый операнд должен быть указателем. В него помеща¬ 
ется потенциальный адрес создаваемой машины с директивной 
«информацией, санкционирующей в коде доступа чтение, запись, 
•копирование и уничтожение. Второй операнд должен быть ука- 
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зателем (с санкционированным чтением) на точку входа в мо¬ 
дуль. Третий операнд должен иметь целочисленное значение, 
задающее объем имеющейся в распоряжении памяти (измеряе¬ 
мой количеством AM), который должен быть передан создан¬ 
ной процесс-машине от данной процесс-машины (см. следую¬ 
щий раздел). 

Четвертый операнд определяет единственный фактический 
параметр, который может быть передан при вызове модуля по 
указанной точке входа. Этот операнд должен быть указателем 
с санкционированием копирования в коде доступа. Созданная 
новая машина не обеспечивается адресацией к данному ука¬ 
зателю. Вместо этого в новой машине создается копия его зна¬ 
чения, и процесс, выполняемый в рамках новой машины, может 
обращаться к этому значению указателя посредством ячейки 
«параметр». 

Текущая процесс-машина продолжает свою работу с коман¬ 
ды, следующей за командой CMACHINE. Приоритет новой ма¬ 
шины полагается равным приоритету текущей машины. 
Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операнды»), а также ошибки типа «трассировка» 
и «недостаточный объем памяти». Последний тип ошибок реги¬ 
стрируется в тех случаях, когда текущая машина не имеет в 
распоряжении достаточного количества AM (свободной памяти) 
для создания новой процесс-машины или когда для передачи 
новой машине запрошено большее число AM, чем имеется в 
наличии. 


Имя команды. TRANSFER-AM (TRANSAM) 

Выполняемая операция. Пересылка части свободной памяти 
между двумя заданными процесс-машинами. 

Формат. 001Е, ОА, ОА, ОА 

Операнды. Первые два операнда должны быть указателями, 
адресующимися к двум процесс-машинам (один из них может 
адресоваться к текущей процесс-машине). Третий операнд 
должен быть целым (положительным) числом, определяющим 
количество AM (единиц свободной памяти), которое подлежит 
пересылке от процесс-машины, указываемой вторым операндом, 
процесс-машине, задаваемой первым операндом. 

В. коде доступа второго указателя должна быть санкциони¬ 
рована запись; какие-либо требования к коду доступа первого 
указателя не предъявляются. 

Ошибки. Основной набор ошибок (за исключением ошибок 
«несовместимые операнды»), а также ошибки типа «недостаточ¬ 
ный объем памяти». Ошибки последнего типа регистрируются в 
тех случаях, когда количество AM (свободной памяти) в про-* 
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цессе, от которого она должна браться, меньше запрошенной 
величины. 

Примечание. Объем памяти, занимаемый объектом, измеряется 
единицей, называемой AM. Свободная память, измеряемая так 
называемыми наличными (имеющимися в распоряжении) AM, 
является атрибутом процесс-машины и определяет потенциаль¬ 
ные возможности выделения памяти данным процессом. 

Имя команды. CONTROL-PROCESS-MACHINE (XMACHINE> 
Выполняемая операция. Эта команда обладает следующим» 
возможностями: 1) перевода указанной процесс-машины в со¬ 
стояние останова, 2) перевода процесс-машины из состояния 
останова в активное состояние, 3) имитации ошибки для указан¬ 
ной машины и 4) смены значения приоритета указанной ма¬ 
шины. 

Формат: 00 IF, X, О А, ОА 

Операнды. Содержимое поля непосредственных данных (X)- 
длиной 1 токен определяет, какую именно операцию из числа 
возможных выполняет команда: 


Значение X 

Выполняемая операция 

1 

Перевод в состояние останова 

2 

Перевод в активное состояние 

3 

Имитация ошибки 

4 

Смена значения приоритета 


Первый операнд должен быть указателем, содержащим по¬ 
тенциальный адрес (с санкционированием записи) требуемой 
процесс-машины; второй операнд — целое число. 

При Х= 1 указанная процесс-машина переводится в состоя¬ 
ние останова по окончании выполнения очередной команды. 
В состоянии останова никакие команды процесс-машиной не- 
реализуются; выполнение команд может быть продолжено пос¬ 
ле перевода процесс-машины в активное состояние. Процесс- 
машины, находящиеся в состоянии блокировки (по команде- 
GUARD) или ожидания (выполнения обмена с внутренним или 
внешним портом машины), не могут быть сразу же переведе¬ 
ны в состояние останова. В этих случаях при попытке переве¬ 
сти их в указанное состояние они переходят в состояние «ожи¬ 
дание перехода в останов». Фактически процесс-машины бу¬ 
дут переведены в останов сразу же при выходе из состояния! 
блокировки или ожидания. При Х=1 значение второго операн¬ 
да не существенно. 
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При Х = 2 указанная процесс-машина переводится из со¬ 
стояния останова или состояния «ожидание перехода в останов» 
в активное состояние. Если машина находилась в активном 
состоянии, состоянии блокировки или состоянии, при котором вы¬ 
полняемый ею модуль «охраняем», то по данной команде ни¬ 
какие действия не выполняются. При Х=2 значение второго 
операнда также не существенно. 

При Х=3 для указанной процесс-машины моделируется со¬ 
стояние ошибки. При этом процесс-машина выводится из любо¬ 
го состояния, в каком бы она ни находилась, и переводится в 
активное состояние. Значение второго операнда передается в 
качестве пятого фактического параметра кода ошибок (с пре¬ 
образованием в поле длиной 6 токен). 

При Х=4 выполняется изменение приоритета для указан¬ 
ной процесс-машины. В качестве нового значения приоритета 
берется наименьшее из двух возможных: значение второго опе¬ 
ранда или значение приоритета машины, выполняющей данную 
команду. 

Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операнды»), а также ошибки типа «неверный код 
операции» (в случае если X не равно 1, 2, 3 или 4). 

Примечание. Понятие приоритетов, используемое при конкрет¬ 
ной реализации вычислительной системы, не предопределяется 
архитектурой системы SWARD. При работе с приоритетами 
следует учитывать, что большие числовые значения соответст¬ 
вуют более высоким приоритетам. 

Имя команды. DESCRIBE-PROCESS-STACK (DSTACK) 
Выполняемая операция. Описание структуры стека активных 
модулей для заданной процесс-машины. 

Формат. ООП, ОА, ОА, ОА, ОА 

Операнды. Первый операнд должен быть одномерным масси¬ 
вом, каждый элемент которого является двухкомпонентной за¬ 
писью: один компонент — поле из 5 токен, другой — указатель 
(ОА1:: = са*000). 

Второй операнд должен быть целым числом, третий — ука¬ 
зателем, четвертый операнд— указателем, адресующим к не¬ 
обходимой процесс-машине. Специальных требований к коду 
доступа этого указателя не предъявляется. После выполнения 
команды массив содержит информацию о состоянии процесса 
указанной процесс-машины. Информация о каждой активации 
какого-либо модуля этой машины регистрируется в виде отдель¬ 
ного элемента массива: первый элемент — текущая активация, 
второй элемент — предшествующая и т. д. В каждом элементе 
массива поле токенов содержит адрес следующей команды, 
подлежащей выполнению, а указатель ссылается на модуль, 
3 * 
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соответствующий этой активации (в коде доступа указана воз¬ 
можность только копирования). Значение второго операнда оп¬ 
ределяет количество активных модулей в процессе. 

Если число элементов в массиве меньше числа активных мо¬ 
дулей, массив содержит информацию только о самых послед¬ 
них (верхних в стеке) модулях активации. Если число элемен¬ 
тов в массиве превышает число активных модулей, содержимое 
оставшихся элементов массива сохраняется без изменения. 

Если процесс-машина находится в состоянии блокировки, 
ожидания или ожидания перехода в останов (см. описание 
команды DESCRIBE-CAPABILITY), в третий операнд (с воз¬ 
можностью только копирования, санкционированного в коде 
доступа) загружается потенциальный адрес того объекта (мо¬ 
дуля, внутреннего или внешнего порта машины), с которым 
связана блокировка или ожидание. В противном случае в этот 
указатель помещается признак неопределенного значения. 
Ошибки. Основной набор ошибок, за исключением ошибок типа 
«несовместимые операнды». 

Примечание. Для получения другой информации о процесс- 
машине следует воспользоваться командой DESCRIBE- 
CAPABILITY. 

Имя команды. COMPUTE-PROCESS-MACHINE-CAPABILITY 
(СРМСАР) 

Выполняемая операция. Вычисление значения потенциального 
адреса процесс-машины, выполняющей данную команду. 
Формат. 0005, ОА 

Операнды. Операнд должен быть указателем, в который поме¬ 
щается потенциальный адрес данной процесс-машины. В коде 
доступа санкционируется только копирование. 

Ошибки. Основной набор ошибок, за исключением ошибок типа 
«несовместимые операнды» и «неопределенный операнд». 

Имя команды. CREATE-PORT 

Выполняемая операция. Создание объекта «порт». 

Формат. 0017, X, О А 

Операнды. Содержимое поля непосредственных данных (X) 
длиной 1 токен определяет, должен ли данный объект «порт» 
автоматически уничтожаться при разрушении процесс-машины, 
выполняющей данную команду. Значение хххО указывает на та¬ 
кую необходимость. 

Операнд должен быть указателем. Он содержит потенциаль¬ 
ный адрес порта, в коде доступа к которому санкционированы 
чтение, запись, уничтожение и копирование. 

Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операнды» и «неопределенный операнд»), а также 
ошибки типа «недостаточный объем памяти». 
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Имя команды. SEND 

Выполняемая операция. Передача значений указанных операц- 
дов (фактических параметров) через порт другому процессу. 
Выполнение команды не завершается до тех пор, пока другой' 
процесс (по команде RECEIVE) не примет пересылаемые зна¬ 
чения. 

Формат. ОВ, ОА, X, ОА1,...,ОАх 

Операнды. Первый операнд является указателем, адресующим- 
ся к определенному порту (в коде доступа указателя санкцио¬ 
нирована запись). Содержимое поля непосредственных данных: 
(X) длиной 2 токен определяет количество передаваемых факти¬ 
ческих параметров (0—255); следующие за содержимым этого 
поля адреса операндов являются адресами параметров. Пара¬ 
метрами не могут быть литералы, срезы или содержимое яче¬ 
ек «косвенный доступ к данным». 

Ошибки. Основной набор ошибок, а также ошибки типа «непра¬ 
вильное число передаваемых данных». В случае несовпадения 
количества передаваемых (фактических) параметров с количе¬ 
ством принимающих (формальных) параметров в соответствую¬ 
щей команде RECEIVE регистрируется ошибка «неправильное 
число передаваемых данных». Если передаваемые (фактиче¬ 
ские) параметры несовместимы по типу с принимающими (фор¬ 
мальными) параметрами при выполнении команды RECEIVE, 
то регистрируется ошибка «несовместимые операнды». Если 
значение какого-либо из фактических параметров не определе¬ 
но, регистрируется ошибка «неопределенный операнд». 

Любая ошибка, регистрируемая после начала пересылки 
данных («нарушение защиты доступа», если фактический па¬ 
раметр— указатель без санкционирования на копирование, «не¬ 
совместимые операнды», «неопределенный операнд»), влечет за 
собой завершение команды SEND и соответствующей ей коман¬ 
ды RECEIVE с неполной передачей данных. Таким образом, 
эти ошибки, как и ошибка «неправильное число передаваемых 
данных», оказывают одновременное воздействие на команду 
SEND и соответствующую ей команду RECEIVE. 

Примечание. Представление внешних устройств ввода-вывода 
(устройств без памяти) в качестве объектов «порт» системы и 
особенности использования команд SEND и RECEIVE в таких 
случаях рассматриваются в следующем разделе. 

Имя команды. RECEIVE 

Выполняемая операция. Пересылка значений первого множест¬ 
ва фактических параметров (каждое отдельное множество этих 
параметров является совокупностью фактических параметров, 
перечисляемых в одной команде SEND) заданного порта по 
указанным адресам операндов и изъятие их из порта. Если в 
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■момент выполнения команды RECEIVE порт не содержит на¬ 
бора значений подобных параметров, выполнение этой коман¬ 
ды не завершается до тех пор, пока группа соответствующих 
параметров не поступит в порт. 

Формат. ОС, ОА, X, ОА1, ... ОАх 

Операнды. Первым операндом является указатель, адресующий 
к порту (в коде доступа к нему должно быть санкционировано 
чтение). В поле непосредственных данных (X) длиной 2 токен 
указывается число принимающих операндов. Следующие за со¬ 
держимым этого поля адреса операндов определяют местопо¬ 
ложение принимающих операндов. Последние могут быть опе¬ 
рандами любого типа, но не литералами, срезами или содержи¬ 
мым ячейки «косвенный доступ к данным». (Для принимающих 
операндов не обязательно использовать ячейки «параметр», по¬ 
скольку фактические параметры передаются в порт по значе¬ 
нию. Если же принимающий операнд —параметр, его значение 
пересылается соответствующему фактическому параметру, пе¬ 
реданному данному модулю при вызове последнего по команде 
CALL или LCALL.) 

В отношении совместимости операндов SEND и RECEIVE 
справедливы те же правила, что и для команды ACTIVATE 
(атрибуты соответствующих посылающих и принимающих опе¬ 
рандов команд SEND и RECEIVE должны быть одинаковы). 
Ошибки. Основной набор ошибок, а также ошибки типа «не¬ 
правильное число передаваемых данных». Если один или не¬ 
сколько фактических параметров имеют неопределенные значе¬ 
ния, если число посылающих операндов (фактических парамет¬ 
ров) в команде SEND не равно числу принимающих операндов 
(формальных параметров) в команде RECEIVE, если хотя бы 
один из операндов SEND не совместим с соответствующим опе¬ 
рандом RECEIVE или если операндом SEND является указа¬ 
тель без санкции на копирование, то в обеих командах — RE¬ 
CEIVE и соответствующей команде SEND — регистрируются 
ошибки типа «неопределенный операнд», «неправильное число 
передаваемых данных», «несовместимые операнды» или «нару¬ 
шение защиты доступа». 

Имя команды. GUARD 

Выполняемая операция. Если выполняемый модуль не находит¬ 
ся в состоянии «охраняем», данная команда вводит его в это 
состояние и передает управление следующей команде. Если же 
выполняемый модуль пребывает в состоянии «охраняем», ра¬ 
бота данной процесс-машины блокируется до момента выхода 
модуля из этого состояния. 

Формат. 001С 

Ошибки. Имитация ошибки. 
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Примечания. Если команда GUARD встречается после того, как 
ранее эта же процесс-машина ввела данный модуль в состоя¬ 
ние «охраняем», то по этой команде не выполняется никаких 
действий. Единственной возможностью вывода модуля из со¬ 
стояния «охраняем» является выполнение команды UNGUARD. 
Выполнение команды RETURN или аномальное окончание дан¬ 
ной активации модуля (например, вследствие возврата в про¬ 
грамму обработки ошибок более высокого уровня) не оказыва¬ 
ет влияния на состояние «охраняем» модуля. 

Имя команды. UNGUARD 

Выполняемая операция. Вывод модуля из состояния «охраня¬ 
ем». 

Формат. 00 1D 

Ошибки. Имитация ошибки. 

Имя команды. DELAY 

Выполняемая операция. Задержка работы процесс-машины на 
указанный интервал времени. 

Формат. 0023, ОА 

Операнды. Операнд должен быть целым числом. Если его зна¬ 
чение отрицательное или равно нулю, то по команде DELAY 
не выполняется никаких действий. В противном случае работа 
процесс-машины приостанавливается на V мс, где V —значе¬ 
ние операнда. В этом состоянии процесс-машины команды не 
выполняются, и на это время часть системных ресурсов, исполь¬ 
зуемых процесс-машиной, может быть возвращена обратно си¬ 
стеме (что именно подлежит возврату определяется конкретной 
реализацией вычислительной системы). 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «несовместимые операнды». 


КОМАНДЫ ОТЛАДКИ 
Имя команды. ENABLE 

Выполняемая операция. Выполнение логической операции ИЛИ 
(OR) над содержимым заданного поля токенов и поля кода 
обрабатываемых ошибок в заголовке модуля с записью резуль¬ 
тата в поле этого кода. Результирующий код хранится в запи¬ 
си активации модуля, что означает, что данная команда воз¬ 
действует только на текущую активацию модуля. 

Формат. 0018, ОА 

Операнды. Операнд должен быть полем токенов, размер кото¬ 
рого (N) не превосходит длину поля кода обрабатываемых 
ошибок. Если указанное поле короче поля кода обрабатывае- 
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■мых ошибок, в последнем могут быть изменены значения лишь 
первых N токен. 

■Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операнды»), а также ошибки типа «переполнение». 
Примечание. Команды ENABLE и DISABLE не ^изменяют код 
обрабатываемых ошибок в самом модуле; их действия влияют 
только на текущую активацию модуля. 

Имя команды. DISABLE 

Выполняемая операция. Логическое отрицание (подразрядная 
инверсия) содержимого заданного поля токенов с последующим 
выполнением логической операции И (AND) над этой величи¬ 
ной и кодом обрабатываемых ошибок в модуле и загрузкой ре¬ 
зультата в запись активации. 

Формат. 0019, ОА 

Операнды. См. команду ENABLE 

Ошибки. Основной набор ошибок (за исключением ошибок «не¬ 
совместимые операнды»), а также ошибки типа «переполне¬ 
ние». 

Имя команды. RAISE-FAULT 

Выполняемая операция. Формирование состояния «ошибка» с 
записью в поле непосредственных данных (X) длиной 2 токен 
величины, определяющей тип (номер) ошибки (т. е. значение, 
передаваемое программе обработки ошибок в качестве первого 
фактического параметра). 

Формат. 000D, X 

Ошибки. Возможны ошибки любого типа, задаваемого в поле 
непосредственных данных (X), а также ошибки «имитация 
ошибки». Значение X не должно быть нулевым или находиться 
в пределах 24—27. Если возникает такая ситуация, то регист¬ 
рируется ошибка «недопустимая обработка ошибок». Если зна¬ 
чение X не соответствует типам ошибок, предусмотренным ар¬ 
хитектурой системы, ошибки считаются программно-определяе¬ 
мыми (28—255). Среди последних ошибки с четными номерами 
позволяют продолжение выполнения команд программы обра¬ 
ботки ошибок после команды RAISE-FAULT, а при нечетных 
номерах ошибок этого не происходит. 

Имя команды. CONTINUE (CONT) 

Выполняемая операция. Завершение выполнения программы 
обработки ошибок и передача управления команде, которая вы¬ 
полнялась бы следующей, если бы ошибка не была обнаруже- 

Формат. 000Е 
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Ошибки. Возможны ошибки типа «недопустимая обработка 
ошибок» [если в данный момент ошибки отсутствуют, если про¬ 
должение работы (по команде CONTINUE) для ошибки данно¬ 
го типа не допустимо или если команда CONTINUE принадле¬ 
жит внутренней программе, вызванной программой обработки 
ошибок], а также ошибки типа «имитация ошибки». 

Примечание. При необходимости выйти из программы обработ¬ 
ки ошибок с целью повторения выполнения команды, вызвав¬ 
шей ошибку, эта программа должна «потребовать» выполнения 
команды LRETURN. Если же необходимо перейти от обработ¬ 
ки ошибки к выполнению команды, следующей за командой, 
вызвавшей ошибку, то программа обработки ошибок должна 
«потребовать» выполнения команды CONTINUE. Однако ука¬ 
занная команда может применяться только при регистрации 
ошибок типа «трассировка» или программно-определяемых оши¬ 
бок с четными номерами (28—254), генерируемых командой 
RAISE-FAULT. 

Имя команды. TRANSFER-FAULT (TRFAULT)' 

Выполняемая операция. Завершение выполнения данной про¬ 
граммы обработки ошибок и вызов программы обработки оши¬ 
бок более высокого уровня (более низкого в стеке записей 
активации). Если требуемая программа обработки не может 
быть найдена, выполнение текущего модуля завершается. 
Формат. 0015 

Ошибки. Возможны ошибки типа «недопустимая обработка 
ошибок» (в первом и третьем случаях, указанных в описании 
команды CONTINUE). 

Примечание. Команда TRFAULT предназначена для использо¬ 
вания в тех случаях, когда данная программа обработки оши¬ 
бок предусматривает обработку ошибок встретившегося типа, 
однако после начала обработки принимается решение о ее об¬ 
работке программой обработки ошибок более высокого уровня. 

Имя команды. TRACE 

Выполняемая операция. Разрешение или запрет на выполнение 
трассировки определенного типа для заданного модуля. 
Формат. 0013, X, О А 

Операнды. Первый операнд — содержимое поля непосредствен¬ 
ных данных (X) длиной 2 токен — определяет тип трассировки: 
значение OOOOxYxx задает трассировку переходов по условию 
«Да»; значение OOOOxxYx — трассировку переходов по условию 
«Нет»; OOOOxxxY — трассировку выполнения обращений по 
команде CALL; OOOOYxxx — трассировку маркера. Если Y=l„ 
трассировка соответствующего типа разрешена; если Y=(T, то 
запрещена. Второй операнд должен быть указателем,, адресу- 
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ющимся к модулю с санкционированием записи в коде доступа. 
Задаваемое командой TRACE разрешение на выполнение трас¬ 
сировки того или иного типа сохраняет силу и для всех после¬ 
дующих активаций модуля. 

Трассировка условных переходов по условиям «Да» и «Нет» 
может запрашиваться для всех команд типа «сравнения — пе¬ 
реход» (COMPARISON-AND-BRANCH), за исключением команд 
ITERATE и ITERATE-REVERSE. Если реализация команды 
указанного класса приводит к необходимости выполнения пе¬ 
рехода, а в данном модуле разрешена трассировка условных 
переходов по условию «Да», то регистрируется ошибка типа 
«трассировка». Аналогично если при реализации команды ука¬ 
занного класса возникает необходимость продолжения последо¬ 
вательного выполнения команд без перехода, а в модуле раз¬ 
решена трассировка переходов по условию «Нет», то также ре¬ 
гистрируется ошибка типа «трассировка». Если в модуле раз¬ 
решена трассировка выполнения вызова по команде CALL, то 
ошибка «трассировка» регистрируется при каждом выполнении 
команды CALL, LCALL или CREATE-PROCESS-MACHINE. 
Если в модуле разрешена трассировка маркера, ошибка «трас¬ 
сировка» регистрируется при выполнении каждой команды 
MARKER. Обнаружение ошибки «трассировка» сопровождает¬ 
ся передачей программе обработки ошибок в качестве пятого 
фактического параметра одного из следующих значений: 

000001 —переход по условию «Да»; 

000002 — переход по условию «Нет»; 

000003 — выполнение команды CALL, LCALL или CREATE- 
PROCESS-MACHINE; 

000004 — выполнение команды MARKER. 

Ошибки. Основной набор ошибок, за исключением ошибок ти¬ 
па «неопределенный операнд» и «несовместимые операнды». 
Примечание. На систему возлагается функция обеспечения пе¬ 
рехода на новый установленный режим трассировки не позднее, 
чем со следующего входа (например вызовом по команде 
CALL, переходом в результате обработки ошибок или по коман¬ 
де RETURN) в указанный модуль. 


Имя команды. MARKER 

Выполняемая операция. Генерирование ошибки типа «трасси¬ 
ровка», если разрешена трассировка маркера. Если такого раз¬ 
решения нет, то никаких действий по данной команде не вы¬ 
полняется. 

Формат. F 

Ошибки. Возможны юшибки типа «трассировка» и «имитация 
ошибки». 



НАБОР КОМАНД СИСТЕМЫ SWARD 43 


Имя команды. RANGE-CHECK (RANGECHK) 

Выполняемая операция. Регистрация ошибки «выход за преде¬ 
лы допустимых значений», если значение первого операнда 
меньше значения второго операнда или больше значения треть¬ 
его операнда. 

Формат. OF, ОА, ОА, ОА 

Операнды. Операнды должны быть числами или символами. 
Если это числа, то они должны быть одного и того же типа 
(целыми, целыми увеличенной разрядности, порядковыми, де¬ 
сятичными с фиксированной или плавающей точкой). Если учи¬ 
тывать это требование, то данная команда оказывается экви¬ 
валентной выполнению последовательности команд: 

GEBF ОА1,ОА2,!1 

LEBF OAl.OA3.il 

где !1 обозначает адрес команды RAISE-FAULT, определяю¬ 
щей ошибку «выход за пределы допустимых значений». 
Ошибки. Основной набор ошибок, а также ошибки типа «вы¬ 
ход за пределы допустимых значений». 

ОСОБЕННОСТИ ДЕЙСТВУЮЩЕЙ СИСТЕМЫ 
РАССМАТРИВАЕМОЙ АРХИТЕКТУРЫ 

При реализации архитектуры системы SWARD на практике 
особое внимание следует уделить трем командам, от которых 
зависит надежность функционирования механизма потенциаль¬ 
ной адресации. Команда CREATE-MODULE должна сканиро¬ 
вать адресное пространство и область размещения команд с 
целью проверки, все ли адреса операндов, являющиеся адре¬ 
сами ячеек, представляют собой обращения ко всей ячейке. Не 
исключаются случаи создания программ, команды которых 
содержат обращения к отдельным элементам ячеек, что, вообще 
говоря, можно рассматривать как не предусмотренные архи¬ 
тектурой возможности создания потенциальных адресов. Это 
можно предотвратить посредством команды CREATE-MODU¬ 
LE, сканирующей сначала адресное пространство с целью оп¬ 
ределения начала каждой ячейки, а затем прибегнув к другой 
команде для выяснения, являются ли адреса ячеек допустимы¬ 
ми к использованию. 

В качестве альтернативного решения данной проблемы мож¬ 
но было бы предложить использовать в качестве адресов опе¬ 
рандов номера ячеек, т. е. ввести нумерацию ячеек: ячейка 1, 
ячейка 2 и т. д. Однако при этом вводился бы дополнительный 
уровень адресации при обработке команды. (Можно было бы 
пользоваться номерами ячеек во внешнем модуле, а посредст¬ 
вом команды CREATE-MODULE преобразовывать их в адреса 
ячеек объекта «модуль», но это не проще сканирования, кота- 
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рое должна выполнять эта команда для определения, допусти¬ 
мы ли адреса ячеек к использованию.) 

Сказанное относится и к командам COMPUTE-CAP ABILITY- 
EXTERNALLY и COMPUTE-ENTRY-CAPABILITY. Вычисли¬ 
тельная система должна удостовериться, что она адресуется ко 
всей ячейке полностью, а команды, к которым производится 
обращение, содержат адреса ячеек, допустимые к использо¬ 
ванию. 

Ни одна из команд системы не является прерываемой, т. е. 
командой, имеющей определенные, промежуточные состояния, 
позволяющие приостановить выполнение команды, обработать 
другие команды, а затем продолжить выполнение прерванной 
команды. Некоторые вычислительные системы имеют прерывае¬ 
мые команды (например, команда MOVE-CHARACTER-LONG 
в Системе 370). В системе SWARD от использования таких 
команд отказались по двум причинам. Во-первых, почти все 
команды системы SWARD могут выполняться достаточ¬ 
но долго; предусмотреть возможность их прерывания озна¬ 
чало бы необычайное усложнение архитектуры системы. Во-вто¬ 
рых, принцип прерываемости команд не соответствует заложен¬ 
ным в данную архитектуру принципам функционирования про¬ 
цесс-машин. Если придерживаться этих принципов, то при срав¬ 
нительно низкой стоимости в настоящее время реальных про¬ 
цессоров, естественным оказывается построение системы 
SWARD на нескольких процессорах (конечно, не следует отож¬ 
дествлять их количество с количеством процесс-машин, посколь¬ 
ку последние могут свободно создаваться и уничтожаться). Ес¬ 
ли же создать реальную систему, в которой несколько недоро¬ 
гих процессоров поддерживают существование переменного 
числа процесс-машин, необходимость в прерываемых командах 
отпадает. 

Отметим, что в описаниях команд DESCRIBE-CAPABILITY, 
CONTROL-PROCESS-MACHANE и CREATE-PROCESS- 
MACHINE используется понятие приоритетов процесс-машин, 
не детализируемое архитектурой и уточняемое на этапе реали¬ 
зации системы. Так, на основе различия приоритетов процесс- 
машин можно организовать очередность их доступа к памяти, 
определить объем работ, выполняемых для каждой процесс-ма¬ 
шины небольшим набором реальных процессоров, управлять 
местоположением каждой процесс-машины во внешних очере¬ 
дях (например, у портов или в ожидании выхода модуля из со¬ 
стояния «охраняем», задаваемого командой GUARD). 

В рассматриваемой системе запись активации является в оп¬ 
ределенном смысле уникальным объектом, поскольку допускает 
потенциальную адресацию только к ячейке внутри объекта, но 
не ко всему объекту. Потенциальный адрес будет относиться к 
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ячейке внутри записи активации, если он рассчитывается мо¬ 
дулем для ячейки, относящейся к динамической части адресного 
пространства. Поскольку это встречается редко и, кроме того, 
в связи с тем что записи активации являются наиболее часто 
создаваемыми объектами (большинство системных имен прихо¬ 
дится на них), целесообразно формировать для них уникальные 
имена автоматически. Предпочтение следует отдать такому ре¬ 
шению, при котором команды, вычисляющие потенциальные ад¬ 
реса, например команда COMPUTE-CAPABILITY, при обра¬ 
щении к ячейкам из динамической части адресного простран¬ 
ства определяют, имеет ли уже запись активации системное имя 
(SON). Если имени нет (первое обращение к области), то оно 
присваивается во время выполнения команды. 

ОСОБЕННОСТИ ПРЕДОСТАВЛЕНИЯ 
ПАМЯТИ ПРОЦЕСС-МАШИНАМ 

Система SWARD является моделью вычислительной машины, 
имеющей неограниченный резерв процессоров (процесс-машин) 
при фиксированном, хотя и большом, объеме памяти, являю¬ 
щейся памятью одного уровня. «Порциями» фиксированного 
объема эта память может распределяться между всеми суще¬ 
ствующими в данный момент процесс-машинами. 

Как было упомянуто выше, предусмотрена специальная еди¬ 
ница измерения объема памяти — AM (amount of storage — пор¬ 
ция памяти). Конкретное значение AM не определяется архи¬ 
тектурой системы SWARD; это значение задается в процессе 
практической реализации вычислительной системы. 

При реализации системы SWARD допускается также зада¬ 
ние некоторого минимального значения AM для любого объ¬ 
екта, размер которого меньше «стандартного», т. е. фиксирован¬ 
ного для проектируемого варианта системы. Это делается с 
целью экономии ресурсов системы, «поглощаемых» процесс-ма¬ 
шиной, которая (согласно принципам архитектуры системы 
SWARD) должна помнить все имена существующих в системе 
объектов. 

Количество AM, выделяемое объектам конкретной реализо¬ 
ванной системы, можно узнать, предусмотрев вывод на печать 
таблицы израсходованных AM. Подобную информацию можно 
получить также путем создания интересующих пользователя 
юбъектов с последующим выполнением команды DESCRIBE- 
CAPABILITY для определения количества AM, выделенного 
этим объектам. 

Для существующей реализации системы SWARD можно со¬ 
ставить представление о величине AM на оснований следующих 
примеров: 
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1) 200 объектов «порт» занимают ~ 1 AM; 

2) объекту «память данных» для массива из 200 10-символь¬ 
ных полей необходим ~ 1 AM; 

3) объект «модуль», соответствующий изображенному на 
рис. 14.11 внешнему модулю, занимает 0,1 AM; 

4) записи активации модуля «объект» требуется <0,1 AM; 

5) объекту «процесс-машина» необходим 0,1 AM; 

6) процесс, не создающий явным образом новых объектов и 
формирующий сравнительно мало записей активации с неболь¬ 
шим количеством ячеек, соответствующих динамической части 
адресного пространства, требует для своего выполнения 
<1 AM. 

При конкретной реализации архитектуры системы SWARD 
допускается также организация подсистем так называемого. 
быстрого распределения памяти для ограниченного числа не¬ 
больших, часто создаваемых объектов (например, записей ак¬ 
тивации, длина которых меньше некоторой пороговой величи¬ 
ны). Быстрое распределение памяти производится без обраще¬ 
ния к памяти процесс-машины (без уменьшения величины AM 
имеющейся в ее распоряжении памяти). При этом при выдаче 
информации о памяти, занимаемой объектами, требующими 
менее 1 AM памяти, система может генерировать нулевое зна¬ 
чение. 

Количество требуемых единиц AM можно рассматривать как 
характеристику (атрибут) объекта. В то же время для объекта 
«процесс-машина» можно указать еще одну характеристику: 
количество имеющихся в наличии AM, т. е. объем имеющейся в 
распоряжении свободной памяти. Речь идет о памяти, которой 
располагает данная процесс-машина для создания новых объ¬ 
ектов. Имеющаяся свободная память перераспределяется меж¬ 
ду процесс-машинами как во время их создания, так и при их 
уничтожении. Она может также перераспределяться динамиче¬ 
ски по специальному запросу. Когда создается новая процесс- 
машина, ей передается определенная часть свободной памяти, 
которой располагает исходная процесс-машина. Переданная 
процесс-машине свободная память становится свободной па¬ 
мятью этой машины. Величина переданной свободной памяти 
вычитается из величины AM свободной памяти, имеющейся ві 
исходной процесс-машине. Перераспределение свободной памя¬ 
ти между данной процесс-машиной и другой процесс-машиной 
или между двумя другими процесс-машинами может выполнять¬ 
ся с помощью команды TRANS AM. 

При начальном запуске система содержит одну процесс-ма¬ 
шину, выполняющую программу определенного встроенного 
модуля. Эта процесс-машина охватывает всю свободную па¬ 
мять, имеющуюся в системе. 
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При создании любого нового объекта (в том числе объек¬ 
та «процесс-машина») объем свободной памяти, имеющийся в 
распоряжении исходной процесс-машины, уменьшается на ве¬ 
личину (измеряемую в AM), которая необходима для создания 
объекта. Если количества AM свободной памяти для этой цели 
недостаточно, объект не создается и регистрируется ошибка «не¬ 
достаточный объем памяти». 

Когда некоторый объект уничтожается по явному запросу, 
размер занимаемой им памяти (в AM) добавляется к количе¬ 
ству AM свободной памяти процесс-машины, выполняющей 
команду DESTROY. Если уничтожаемым объектом является 
процесс-машина, то к количеству AM свободной памяти про¬ 
цесс-машины, выполняющей команду DESTROY, добавляется 
также количество AM свободной памяти уничтожаемой процесс- 
машины. 

При уничтожении некоторого объекта косвенным путем (как 
следствие уничтожения процесс-машины) занимаемая им па¬ 
мять добавляется к свободной памяти уничтожаемой процесс- 
машины 15 . Отметим, что процесс-машина может косвенным пу¬ 
тем уничтожить саму себя (при возврате управления из перво¬ 
начальной активации), а также может уничтожить себя по яв¬ 
ному запросу командой DESTROY. В этих случаях свободная 
память этой процесс-машины передается процесс-машине (если 
она еще существует), обусловившей появление данной процесс-. 
машины, или процесс-машине, инициировавшей этот процесс. 

Все упомянутые случаи перераспределения памяти, выпол¬ 
няемые системой, можно реализовать по явному запросу с по¬ 
мощью команды TRANSAM. 

Отметим, что понятие процесс-машины является независи¬ 
мым (ортогональным) по отношению к другим понятиям, свя¬ 
занным с архитектурой системы SWARD. Например, нет взаи¬ 
мозависимости функционирования процесс-машин и системы ад¬ 
ресации. 

ЭФФЕКТИВНОСТЬ ВЫПОЛНЕНИЯ 
СИСТЕМОЙ SWARD ОПЕРАТОРОВ 
ЯЗЫКОВ ВЫСОКОГО УРОВНЯ 

Анализировать эффективность работы SWARD можно по 
крайней мере по трем основным направлениям. Одно из них — 
анализ «на макроуровне». В этом случае интересуются не кон¬ 
кретным быстродействием машины, а общей эффективностью 
решения основных задач, стоящих перед системой (т. е. эффек- 


" В конечном счете — к количеству AM свободной памяти процесс-маши¬ 
ны, вызвавшей уничтожение. — Прим, перев. 
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тивностью обеспечения интерфейса человек —машина). Учиты¬ 
вая общую ориентацию архитектуры системы SWARD на со¬ 
здание благоприятной среды для разработки и выполнения про¬ 
грамм, нельзя считать не имеющим под собой основу утверж¬ 
дение, что при таком подходе система SWARD отличается на¬ 
много более высокой эффективностью по сравнению даже с со¬ 
временными сверхбольшими ЭВМ. Поскольку, однако, для 
оценки подобной эффективности трудно предложить определен¬ 
ную меру, рассматриваемый подход не позволяет дать количе¬ 
ственную оценку системы SWARD. 

Второе возможное направление анализа эффективности си¬ 
стемы SWARD предполагает рассмотрение «на уровне систе¬ 
мы». В этом случае объектом оценки также не является время 
выполнения операторов, им служит эффективность выполнения 
стандартных системных программ. Рассматривается влияние 
особенностей архитектуры на реализацию различных функций 
системы: влияние фундаментальных принципов системы (потен¬ 
циальной адресации, распределения вычислительного процесса 
между отдельными процесс-машинами, пересылки данных через 
порты) на работу программ операционной системы, влияние по¬ 
вышенной компактности программ на пересылку данных между 
запоминающими средами различного уровня. 

Третье направление анализа эффективности системы SWARD 
связано с использованием традиционных оценок работы систе¬ 
мы на «микроуровне». Здесь критерием эффективности счита¬ 
ется скорость выполнения операторов небольших фрагментов 
программ. На первый взгляд может показаться, что по этому 
критерию система SWARD имеет плохие показатели. Однако 
это не так, и главным образом благодаря большому значению 
параметра (меры) М. 

В качестве примера рассмотрим эффективность обработки 
строк символов различными вычислительными системами. 
В частности проанализируем операции выделения подстроки, 
вычисления ее длины, поиска подстроки и ее присоединения к 
строке на языке ПЛ/1 для строк постоянной и переменной 
длины, а также для строк, длина которых определяется в мо¬ 
мент вызова процедуры (использование символа * для указа¬ 
ния длины в определениях строк на языке ПЛ/1). Сравнение 
проводится с моделью 158 Системы 370, в которой использу¬ 
ется разработанный фирмой IBM оптимизирующий компилятор 
языка ПЛ/1. 

Текст рассматриваемой программы на языке ПЛ/1 представ¬ 
лен на рис. 15.1. При выполнении процедуры передавались па¬ 
раметры следующих типов: CHARACTER (80) VARYING; CHA¬ 
RACTER (6); FIXED-BINARY (15) со значением 1; FIXED¬ 
BINARY (15) со значением 5. 
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STRTEST: PROCEDURE (A,B,I,J); /* STRINGSIZE.STRINGRANGE OFF */ 

DCL A CHAR(*) VARYING; 

DCL В CHAR(*); 

DCL C CHAR(20) VARYING; 

DCL D CHAR(8) INIT(’12345678’); 

DCL E CHAR(8); 

DCL F CHAR(l); 

DCL G CHAR(2) INIT('DE'); 

DCL H CHAR(80); 

DCL X BIT(4); 

DCL Y BIT(16) VARYING INIT(' ЮЮОЮООЮОООЮ'В) ; 

DCL (I,J,K,L,M) FIXED BINARY(15); 

130 C = SUBSTR(A,I,J); /* C = 'AAAAA' LENGTH 5 */ 

/* SUBSTR TO LOCAL VARYING FROM PARAM * VARYING *f 
150 F = SUBSTR(D,J,I); /* F = '5' */ 

/* SUBSTR TO LOCAL FROM LOCAL */ 

170 SUBSTR(E,I,I+J) = В; /* E = 'ABCDEF??' */ 

/* SUBSTR INTO LOCAL FROM PARAM * */ 

190 SUBSTR(E,I,J) = SUBSTR (С, I,J); /* E = 'AAAAAF??' */ 




/* 

SUBSTR INTO LOCAL FROM SUBSTR FROM LOCAL VARY *f 

210 

С = 

С II G; 

1* C = 1 AAAAADE' LEN 7 */ 



/* 

CONCAT LOCAL TO LOCAL VARYING */ 

230 

С = 

С И В; 

/* C = ’AAAAADEABCDEF' LEN 13 */ 



/* 

CONCAT PARAM * TO LOCAL */ 

250 

К = 

LENGTH (А); 

/* К = 80 */ 



/* 

LENGTH OF PARAM * VARYING */ 

270 

М = 

LENGTH(C) ; 

/* M = 13 */ 



/* 

LENGTH OF LOCAL VARYING */ 

290 

Н = 

А; 

/* H = AAAAAAAAAABBB. ... (80 CHARS) */ . 



/* 

80-CHAR MOVE FROM PARAM * VARYING */ 

310 

L = 

INDEX(A,G) ; 

/* L = 40 */ 



/* 

INDEX OF LOCAL 2-CHAR IN PARAM * VARYING */ 

330 

I = 

INDEX(H,B) ; 

/*1=0 (NOT FOUND) */ 



/* 

INDEX OF PARAM * IN LOCAL */ 

350 

X = 

SUBSTR(Y,J, 4); 

; /* X = '0100'B */ 


/* SUBSTR TO LOCAL BIT FROM LOCAL BIT VARYING */ 

END STRTEST; 

Рис. 15.1. Программа на языке ПЛ/1. 


Текст программы не требует дополнительных пояснений. Все 
операторы, кроме оператора, находящегося в строке с номером 
350, выполняют стандартные функции по обработке строк сим¬ 
волов. Что касается операции выделения подстроки в строке 
битов, она встречается относительно редко, поскольку ее реали¬ 
зация в Системе 370 связана с преодолением ряда затруднений. 
С целью упрощения сопоставления результатов работы сравни¬ 
ваемых систем упомянутую операцию можно не принимать в 
расчет. 

Для целей сравнения использовались два варианта програм¬ 
мы на языке ПЛ/1. Один из них, как было упомянуто выше», 
представлен на рис. 15.1. Второй вариант программы отлича- 


4-429 
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ется от первого только наличием программных средств STRING 
SIZE и STRINGRANGE, обеспечивающих на этапе выполнения 
•программы проверку двух условий: принадлежности адреса 
подстроки области, занимаемой строкой, и отсутствия перепол¬ 
нения при выполнении присваивания значения строке символов. 
„Имея в виду защищенность программы от ошибок программи¬ 
ста, первый из двух рассматриваемых вариантов можно назвать 
«незащищенной» программой, а второй — «защищенной». При 
создании программ для производственной эксплуатации безус¬ 
ловно целесообразно включение в их текст средств проверки 

: STRTEST MODULE 

DATA SPACE 

.A DCL CHAR,(*,VARYING),PARAMETER 
В DCL CHAR,(*).PARAMETER 
-C DCL CHAR,(20,VARYING),AUTOMATIC 
D DCL CHAR,(8),INIT='12345678'.AUTOMATIC 
E DCL CHAR,(8),AUTOMATIC 
T DCL CHAR,(1),AUTOMATIC 
G DCL CHAR,(2),INIT='DE',AUTOMATIC 
H DCL CHAR,(80),AUTOMATIC 
X DCL BOOLEAN,(4),AUTOMATIC 

Y DCL BOOLEAN, (16,VARYING).,INIT-B'1010010001000010' .AUTOMATIC , 

T DCL INTEGER,PARAMETER 
J DCL INTEGER,PARAMETER 
К DCL INTEGER,AUTOMATIC 
L DCL INTEGER,AUTOMATIC 
M DCL INTEGER,AUTOMATIC 
Tl DCL INTEGER,AUTOMATIC 
T2 DCL INTEGER,AUTOMATIC 
INSTRUCTION SPACE 
ACT (A,B,I,J). 

MOVESS C,l,J,A,I,J 
MOVESS F,1,I,D,J,I 

:move ti,i 

• ADD T1,J 
LENGTH T2,B 
MOVESS E,I,T1,B,1,T2 
•MOVESS E,I,J,C,I,J 
CCAT C ,.G 
CCAT C,B 
LENGTH K,A 
LENGTH M,C 
MOVE H,A 
MOVE L, 1 
INDEX L,0,A,G 
MOVE 1,1 
INDEX I,0,H,B 
MOVESS X,1,4,Y,J,4 
RETURN 

STRTEST MODULE END 
END 

іРис. 15.2. Программа на языке ассеблера системы SWARD. 
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выполнения указанных выше условий (выявление возможностей 
возникновения ошибок). Поэтому при опенке эффективности 
выполнения программ следует сравнивать именно «защищен¬ 
ную» программу с эквивалентной ей программой системы 
SWARD. При этом, конечно, благодаря обширному семантиче¬ 
скому контролю, выполняемому системой SWARD, ее програм¬ 
ма менее подвержена ошибкам, чем «защищенная» программа 
на языке ПЛ/1. 

Остановимся на некоторых событиях, которые имели место 
при работе с рассматриваемой процедурой на языке ПЛ/к 
При написании внешней процедуры, которая должна переда¬ 
вать фактические параметры процедуре, текст которой приве¬ 
ден на рис. 15.1, третий и четвертый из передаваемых парамет¬ 
ров во внешней процедуре были представлены не 15-разряд- 
ными двоичными числами (как это необходимо), а 31-разряд- 
ными. Выполнение программы протекало «успешно» при ис¬ 
пользовании случайных значений I и J, и примерно целый день- 
проводился анализ листинга трассировки, полученного при, 
использовании модели 158, прежде чем случайно была обнару¬ 
жена эта ошибка. Система SWARD такую ошибку выявила бы 
сразу. Более того, когда ошибка была исправлена и програм¬ 
ма выполнялась системой SWARD в режиме трассировки, по¬ 
следняя обнаружила ошибку «несовместимые операнды» при 
выполнении команды ACTIVATE в начале этой процедуры. Эта 
Таблица 15.4. Статистические данные о количестве выполняемых команд 


Номер оператора 
программы 

Количество команд при 

«незащищенном» 
варианте програм¬ 
мы на языке ПЛ/1 
для Системы 370 

«защищенном* 
варианте програм¬ 
мы на языке ПЛ/1 
для Системы 370 

использовании 
программы для си¬ 
стемы SWARD 

Вызов/Возврат 

53 

142 

3 

130 

21 

129 

1 

150 

12 

119 

1 

170 

26 

123 

4 

190 

33 

196 

1 

і 210 

26 

89 

1 

230 

30 

93 

1 

\ ; 250 

3 

3 

Г 

270 

2 

2 

1 

290 

14 

66 

1 

310 

153 

153 

2 

330 

364 

364 

2 

350 

121 

168 

1 

Всего 

858 

1647 

20 


4 * 
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ошибка означает несоответствие типов передаваемых и при¬ 
нимаемых данных. Оказалось, что в вызывающей процедуре 
первый параметр при обращении к данной процедуре не был 
объявлен как VARYING. Из этого следует, что во время рабо¬ 
ты Системы 370 в ряде случаев в операнде не досчитывалось 
двух символов. Однако ошибка не была обнаружена до тех 
пор, пока программа не была выполнена системой SWARD. 

Эквивалентная программа на языке ассемблера системы 
SWARD представлена на рис. 15.2. 

В табл. 15.4 приведены статистические данные о выполняе¬ 
мых командах. Первая строка таблицы содержит количество 
команд, выполняемых для вызова процедуры. К указанным 
командам относятся следующие: 1) последовательность команд 
внешней процедуры, обеспечивающих вызов; 2) команды проло¬ 
га в вызываемой процедуре и 3) команды возврата управления 
в вызывающую процедуру. 

В табл. 15.5 приведен один из важных показателей особен¬ 
ностей реализации быстродействия системы, который не зави¬ 
сит от конкретной реализации системы. В ней указано количе- 


Таблица 15.5. Объем пересылаемых данных для разных программ 


Номер оператора 
программы 

Объем данных (в байтах) 

при 

«незащищенном» 
варианте програм¬ 
мы на языке ПЛ/1 
для Системы 370 

«защищенном» 
варианте програм¬ 
мы на языке ПЛ/1 
для Системы 370 

использовании 

nP c^eMw M SWARD H 

Бызов/Возврат 

506 

1132 

711 1 > 

‘130 

134 

936 

86,5 

.150 

70 

858 

68 

170 

142 

874 

153 

190 

188 

1349 

89,5 

210 

144 

649 

25 

230 

182 

709 

39 

250 

26 

26 

25,5 

270 

12 

12 

19,5 

290 

229 

614 

185,5 

310 

880 

880 

131,5 

330 

1668 

1668 

288 

350 

867 

1040 

44,5 

Прочитано байтов 

4461 

8960 

1417,5 

Записано байтов 

587 

1787 

449 1 ) 

Всего 

5048 

10 747 

1866.5 


SWARD вс 
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ство байтов данных, пересылаемых между процессором и па¬ 
мятью при выполнении программы (так называемая мера М). 
Отметим, что регистры общего назначения Системы 370 счита¬ 
ются частью процессора. В соответствии с этим по команде 
LOAD-REGISTER пересылаются 2 байт данных, а по команде 
LOAD — 8 байт (4 байт для команды и 4 байт для извлекае¬ 
мого из памяти 32-разрядного двоичного слова). 

Информация, относящаяся к Системе 370, хотя и получена 
в результате трассировки выполнения программы на модели 158, 
учитывает только те байты данных, которые необходимы в со¬ 
ответствии с принципами, заложенными в архитектуру системы. 
Так, при использовании модели часто поступает запрос в па¬ 
мять на 4 или 8 байт данных, когда в действительности тре¬ 
буемая информация занимает меньший объем памяти. В этой 
системе выполняется опережающая выборка следующей по по¬ 
рядку команды, несмотря на то что в программе может быть 
нарушено последовательное выполнение команд и осуществлена 
передача управления. Пересылка этой дополнительной инфор¬ 
мации, определяемой спецификой реализации архитектуры си¬ 
стемы, не учитывается в количественных показателях Систе¬ 
мы 370, приведенных в табл. 15.5. Однако в показателях си¬ 
стемы SWARD этот параметр учитывается. Например, процес¬ 
сор системы SWARD может извлекать из памяти 6 токен 
(3 байт), хотя в действительности ему необходима только часть 
этих данных. Таким образом, сведения о Системе 370 содержат 
информацию, минимально необходимую, согласно принципам 
архитектуры этой вычислительной системы, а аналогичные све¬ 
дения о системе SWARD носят несколько завышенный харак¬ 
тер. 

В табл. 15.6 приведено время выполнения операторов при 
использовании модели 158, базовой модели системы SWARD и 
реально не существующей машины SWARD 158, описываемой 
ниже. Количественные показатели для модели 158 получены на 
-основе приводимых в документации характеристик системы. 

При сопоставлении количественных показателей систем сле¬ 
дует принять во внимание их зависимость от особенностей 
реализации архитектуры. На первый взгляд модель 158 пред¬ 
ставляется более быстродействующей, чем базовая модель 
системы SWARD. Однако необходимо учесть ряд факторов. 
Так, система SWARD располагает процессором небольшой 
мощности (порядка 9000 вентилей с представлением дан¬ 
ных только 24 бит, а не 32 бит, как в модели 158). Модель 158 
имеет более высокое быстродействие памяти (24- ІО 6 байт/с для 
кэш-памяти, 13-10 б байт/с для основной памяти; тот же пара¬ 
метр для базовой модели системы SWARD составляет 10- 
- 10® байт/с). У модели 158 более короткий основной цикл (115 нс 
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Таблица 15.6. Время выполнения операторов (значения округлены 
с точностью до микросекунды) 



Время 

выполнения операторов (в микросекундах) при 

ратора про¬ 
граммы 

«незащищен¬ 
ном» варианте 
программы на 
языке ПЛ/1 для 
модели 158 

варианте про¬ 
граммы на язы¬ 
ке ПЛ/1 для 
модели 158 

использовании 
программы для 
базовой модели 
SWARD 

использовании 
программы для 

SWARD 158 

Вызов/Воз- 

63 

147 

98 

79 

130 

18 

118 

24 

18 

150 

10 

109 

19 

15 

170 

22 

ПО 

35 

28 

190 

26 

170 

22 

17 

210 

21 

86 

9 

7 

230 

24 

93 

10 

8 

250 

3 

3 

6 

5 

270 

2 

2 

5 

4 

290 

24 

70 

23 

19 

310 

204 

204 

48 

39 

330 

396 

396 

91 

72 

350 

122 

146 

18 

14 

Всего 

935 

1654 

409 

325 

Нормализо¬ 
ванное 
значение 
(по отно¬ 
шению к 

«незащи¬ 
щенному» 
варианту 
програм¬ 
мы на 
языке 

ПЛ/1 

1,00 

1,77 

0,44 

0,35 

Нормализо¬ 
ванное 
значение 
(по отно¬ 
шению к 

«защи¬ 
щенному» 
варианту 
програм¬ 
мы на 

языке 

ПЛ/1) 


1,00 

0,25 

0,20 
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по сравнению со 160 нс в системе SWARD). Система SWARD 
выполняет намного больше семантических проверок (напри¬ 
мер, проверок типа данных), чем даже «защищенный» вариант 
программы на языке ПЛ/1. Кроме того, в процессоре 158 име¬ 
ется буфер команд, позволяющий осуществлять опережающую 
выборку нескольких команд. Однако ни в одной из этих машин 
не используется принцип конвейерной обработки команд. 

При сопоставлении быстродействия различных систем следу¬ 
ет, конечно, обращать внимание на быстродействие обмена с 
памятью (т. е. на ее пропускную способность). Пропускная 
способность процессора определяется относительно просто 
(цикл обращения к памяти составляет 300 нс, отсутствует рас¬ 
слоение и за каждый цикл может быть записано или прочитано 
до 3 байт данных). Аналогичные показатели для модели 158 за¬ 
висят от типа доступа к памяти и от коэффициента совпадения 
для кэш-памяти. Показатели пропускной способности памяти 
для модели 158 Системы 370 представлены в табл. 15.7. 

Чтобы при сопоставлении систем различной архитектуры по 
возможности исключить влияние особенностей конкретных реа¬ 
лизаций, была теоретически рассмотрена модель системы 
SWARD с процессором, которому присуща специфика реального 
процессора 158. В целом это тот же процессор системы SWARD 
(без буфера команд, с 24-битовым представлением данных), 
однако его основной цикл и скорость обмена с памятью такие 
же, как у процессора модели 158. Расчеты были выполнены 
посредством пакета имитационного моделирования программно¬ 
го обеспечения системы SWARD. Пакет позволяет задавать ско¬ 
рости работы процессора и обмена с памятью в качестве пара¬ 
метров, однако не допускает имитировать кэш-память. Но по¬ 
скольку кэш-память в первом приближении можно рассматри¬ 
вать как средство повышения скорости обмена, в модель за- 
Таблица 15.7. Пропускная способность памяти для модели 158 
Системы 370 


Форма обмена 

Максимальная ско¬ 
рость пересылки 
данных, Мгбайт/с 

1. Чтение последовательно расположенных слов из 

23,8 

кэш-памяти 

2. Чтение случайным образом расположенных слов из 

17,4 

кэш-памяти 

3. Чтение последовательно расположенных слов из ос¬ 


новной памяти 

12,6 

4. Чтение случайным образом расположенных слов из 

3,9 

основной памяти 

5. Запись двойных слов (по 8 байт) в основную память 

11,6 

6. Запись слов (по 4 байт) в основную намять 

4,4 
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кладывалось примерно среднее значение скорости обмена с 
памятью для модели 158 (с учетом повышения быстродействия 
за счет кэш-памяти). 

Данные, полученные для системы SWARD 158, могут быть 
также использованы для определения того, насколько показа¬ 
тель М характеризует скорость выполнения операций. Значе¬ 
ния М были следующими: 10 747 — для «защищенной» програм¬ 
мы на языке ПЛ/1 и 1866,5 — для системы SWARD. Время вы¬ 
полнения соответствующей программы машиной 158 составило 
1654 мкс. Используя значение М, можно высказать предполо¬ 
жение, что для системы SWARD 158 время выполнения оказа¬ 
лось бы равным 287 мкс. В результате же расчетов методом 
имитационного моделирования была получена величина, рав¬ 
ная 325 мкс. Расхождение можно считать незначительным, если 
принять во внимание, что процессор системы SWARD 158 не 
обладает всеми функциональными возможностями мощного про¬ 
цессора модели 158. Для «незащищенного» варианта програм¬ 
мы на языке ПЛ/1 величина М оказалась равной 5048 (при 
1866,5 для системы SWARD). Исходя из времени выполнения 
этой программы на модели 158, равного 935 мкс, соответству¬ 
ющее время для системы SWARD оценивается в 345 мкс, что 
также незначительно отличается от значения, равного 325 мкс, 
полученного путем моделирования. 

Наконец, в табл. 15.8 приводятся размеры загрузочных мо¬ 
дулей рассматриваемой программы. Отметим, что для програм¬ 
мы системы SWARD учитывается память, занимаемая как 
командами, так и тегами. 

В табл. 15.9 дано время выполнения основных команд и ти¬ 
пичных операций. В общем случае оценить время выполнения 
оказывается нелегко по следующим причинам: 1) это время за¬ 
висит от способа адресации операндов (в частности, от того, 
является ли операнд параметром или косвенным доступом к не¬ 
му); 2) вследствие оптимизации микропрограмм, реализующих 
многие команды, скорость выполнения последних оказывается 
Таблица 15.8. Размер памяти, занимаемой разными 
программами 


Вариант программы 

Размер за¬ 
грузочного 
модуля, байт 

«Незащищенный» вариант программы 
на языке ПЛ/1 для Системы 370 

970 

«Защищенный» вариант программы 
на языке ПЛ/1 для Системы 370 

1340 

Программа для системы SWARD 
(включая память, занимаемую те¬ 
гами) 

135,5 



НАБОР КОМАНД СИСТЕМЫ SWARD 57 


Таблица 15.9. Время выполнения некоторых команд и операций 


Команда (операция) 


BRANCH 

MARKER 

MOVE (литерал в ячейку «целое число») 

MOVE [литерал в целочисленный элемент массива А (I)] 
MOVE (целое число, включающее 50 элементов массива или 
■среза) 

ADD (литерал в ячейку «целое число») 

MULTIPLY (целые числа) 

RANGECHECK (целое число, литерал, целое число) 

ITERATE 

SUBTRACT (7-разрядные десятичные числа) 

ALLOCATE (для 80-символьной строки) 

CREATE PROCESS MACHINE 
SEARCH (массив или срез целых чисел) 


8,5 

25,5 

3,9 

3,8-10, 

6,0 

3,7 

5,4 


5 


на элемент 


SEND (один фактический параметр в пустой порт) 
CREATE PORT 

CONVERT |(це.аде число, включающее 8 символов) 
CONVERT <«=45.78» — число с фиксированной точкой) 
CALL 

ACTIVATE (5 параметров) 

RETURN 

Переключение процессов 


21,8 

12,2 

19,1 

21,9 

25-40 1 > 

13.5 

7.5 
7,7 


') Диапазон типичных значений, которые в значительной степени зависят от размера 
создаваемой записи активации. 


зависимой от типа обрабатываемых данных; 3) время выпол¬ 
нения отдельных команд зависит от сложившихся в програм¬ 
ме к данному моменту условий (так, например, обстоит дело 
с командами, которые для создания объектов предварительно 
запрашивают память). 

Если ввести некоторые усовершенствования, можно заметно 
уменьшить время выполнения многих команд. Например, была 
разработана, хотя и не включена в базовую модель системы 
SWARD, подсистема памяти с сохранением информации о по¬ 
следних выполненных операциях. Она представляет собой не¬ 
большую ассоциативную память, содержащую восемь адресов 
ячеек, к которым производилось обращение в последних выпол¬ 
нявшихся командах. Для каждого из этих адресов хранятся 
данные о первых 6 токен тега ячейки и физическом адресе ее 
текущего содержимого. Моделирование этой небольшой допол¬ 
нительной подсистемы показало, что она может уменьшить вре¬ 
мя выполнения основных команд из числа перечисленных в 
табл. 15.9 (пересылка скалярных величин, сложение, сравнение 
н т. п.) на 30—50%. 



ЧАСТЬ VI 

МИКРОПРОЦЕССОР С АРХИТЕКТУРОЙ, 
ОРИЕНТИРОВАННОЙ НА ОБЪЕКТЫ 


ГЛАВА 16 

ОСНОВНЫЕ ПРИНЦИПЫ РАБОТЫ 
МИКРОПРОЦЕССОРА іАРХ 432 

За последние пять-десять лет наиболее значительным достиже¬ 
нием на пути создания новых типов архитектуры ЭВМ следует 
считать разработку фирмой Intel микропроцессора іАРХ 432. 
В основу этой микропроцессорной системы положены многие 
принципы и понятия, рассмотренные в гл. 4 (такие, как «по¬ 
тенциальная адресация», «объекты», «области санкционирован¬ 
ного доступа», «средства управления процессами» и т. п.). На¬ 
лажен массовый выпуск упомянутых типов микропроцессоров, 
что свидетельствует о практической пригодности упомянутых 
принципов и понятий. Реализация микропроцессорной системы 
іАРХ 432 является значительным достижением в области конст¬ 
руирования систем на больших интегральных схемах, поскольку 
ее процессор выполнен на двух интегральных схемах, содержа¬ 
щих по 160 000 полупроводниковых элементов. Только на раз¬ 
работку кремниевой подложки и внутренней топологии элемен¬ 
тов систем затрачено 100 человеко-лет. 

Поскольку архитектура системы іАРХ 432 имеет много об¬ 
щего с архитектурой системы SWARD, по мере возможности 
будем проводить сравнение этих систем. Предполагается, что 
читатель ознакомился с гл. 13—15. Для удобства сравнения 
рассмотрение системы іАРХ 432 будет проводиться примерно в 
том же порядке, что и описание системы SWARD. 

ЦЕЛИ СОЗДАНИЯ АРХИТЕКТУРЫ 
СИСТЕМЫ ІАРХ 432 

Главная задача, стоящая перед разработчиками системы 
іАРХ 432, заключалась в существенном сокращении стоимости 
и времени разработки прикладных программ для микропроцес¬ 
сорной системы. Достижение поставленной цели оказалось воз¬ 
можным благодаря реализации пяти из шести основных требо¬ 
ваний, которым, как указано в гл. 13, должны удовлетворять 
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эффективные вычислительные системы. (Первое из требова¬ 
ний — обнаружение семантических ошибок в программах — как 
цель проектирования системы іАРХ 432 не выдвигалось.) Так, 
ограничение последствий возможных ошибок в программном 
обеспечении системы іАРХ 432 достигается благодаря выбору 
соответствующих принципов адресации и защиты от несанкцио¬ 
нированного доступа. Архитектура іАРХ 432 такова, что облег¬ 
чается процесс проектирования программного обеспечения на 
основе прогрессивных технологических приемов структурирова¬ 
ния, программы для системы іАРХ 432 могут быть приведены к 
более простому виду, чем аналогичные программы для других 
систем. Имеются средства для эффективности тестирования и 
отладки программ; программы операционной системы и другие 
подобные средства программного обеспечения отличаются 
сравнительной простотой. 

Основная цель разработки архитектуры системы іАРХ 432 — 
усовершенствование процесса разработки прикладного и си¬ 
стемного программного обеспечения — обусловлена тем обстоя¬ 
тельством, что именно трудности разработки программ явля¬ 
ются основным препятствием для широкого внедрения вычис¬ 
лительной техники. Достижение поставленной цели проектиро¬ 
вания микропроцессора іАРХ 432 предопределяет и область его 
наиболее широкого применения — создание систем, отличаю¬ 
щихся относительно большой долей стоимости разработки про¬ 
граммного обеспечения в общей стоимости системы. Маловеро¬ 
ятно, что микропроцессор іАРХ 432 будет использоваться во 
многих традиционных областях применения микропроцессоров, 
например в системах управления и контроля функционирования 
электроприборов, автомобилей или терминалов. Это связано с 
тем, что в подобных специализированных вычислительных си¬ 
стемах программирование, как правило, выполняется однократ¬ 
но, поэтому его стоимость составляет малую долю стоимости 
системы. Скорее всего микропроцессор іАРХ 432 найдет при¬ 
менение в следующих случаях: 

1) в более простых объектах, для которых, однако, требу¬ 
ется достаточно большой объем программирования; 

2) в сложных системах, нуждающихся в неоднократном пе¬ 
репрограммировании; 

3) в системах, функционирование которых предполагает на¬ 
личие ряда одновременно выполняющихся параллельных про¬ 
цессов (организации параллельного выполнения процессов в 
микропроцессоре іАРХ 432 уделяется большое внимание); 

4) в системах, для которых необходимо обеспечить надеж¬ 
ную защиту от ошибок программирования (эта характеристика 
программных средств является еще одной важной особенно¬ 
стью микропроцессора іАРХ 432). 




Вторая цель создания системы іАРХ 432 состоит в наделе¬ 
нии проектируемых программных средств свойством адаптируе¬ 
мости структуры, т. е. в обеспечении возможности динамиче¬ 
ского добавления или удаления процессоров, обслуживающих 
заданные программы, без изменения уже разработанного комп¬ 
лекса программных средств. 

Эта цель достигается с помощью специального компонен¬ 
та — пула процессоров, — включенного в архитектуру системы. 
Подобно тому как создаются процесс-машины в системе 
SWARD, в системе іАРХ 432 отдельные процессы из централь¬ 
ной очереди закрепляются за выделяемыми из пула процессо¬ 
рами. Предусмотрены средства для параллельного обслужи¬ 
вания нескольких процессов, для обеспечения работы несколь¬ 
ких процессоров и взаимной синхронизации процессов и процес¬ 
соров. 

Третья цель разработки данной архитектуры — создание си¬ 
стемы высокой надежности, предоставляющей, в частности, воз¬ 
можность программам обрабатывать обнаруживаемые в про¬ 
цессе функционирования как аппаратные, так и программные 
ошибки. Кроме того, такая система должна допускать возмож¬ 
ность изменения собственной конфигурации с подключением до¬ 
полнительных процессоров, работающих независимо от обраба¬ 
тываемых программ и выполняющих контролирующие функции. 

Четвертая цель разработки системы іАРХ 432 — обеспечение 
средств программирования на языке Ада. Структура программ 
для системы іАРХ 432 аналогична структуре программ на язы¬ 
ке Ада (в системе іАРХ 432 имеются, например, такие поня¬ 
тия, как пакет и спецификатор типа объекта). Часть средств, 
связанная с управлением процессами, специально ориентирова¬ 
на на режим обработки задач, запрограммированных на язы¬ 
ке Ада. 

АРХИТЕКТУРА СИСТЕМЫ ІАРХ 432 

Ниже перечислены важнейшие характеристики архитектуры си¬ 
стемы іАРХ 432. Многие из них схожи с соответствующими ха¬ 
рактеристиками системы SWARD; существенное отличие состо¬ 
ит в том, что система іАРХ 432 не располагает теговой памятью. 

ОБЪЕКТЫ 

Объект — это основное понятие архитектуры системы 
іАРХ 432. В гл. 4 показано, что объект представляет собой 
логически взаимосвязанную совокупность данных с набором’ 
применяемых к ним операций (в основном машинных команд). 
Как и в системе SWARD, структура памяти системы іАРХ 432 
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Рис. 16.1. Основные объекты системы и их взаимосвязи. 


может быть представлена в виде сети объектов. Характерные 
объекты и возможные связи между ними изображены на 
рис 16.1. 

Аппаратные средства системы іАРХ 432 включают в свой 
состав объекты следующих типов: домен, порт связи, процес¬ 
сор, ресурсы памяти, аффинаж, транспортер, контекст, порт 
диспетчеризации, справочник таблиц объектов, описание типа ѵ 
данные общего назначения, команды, процесс, таблицу объектов, 
управление дескриптором, доступ к данным общего назначения. 

Перечисленные объекты являются теми объектами системы 
іАРХ 432, которые распознаются процесором обработки данных 
общего назначения (general data processor — GDP), называе¬ 
мым в дальнейшем сокращенно процессором общего назначения 
и являющимся главным процессором этой вычислительной си¬ 
стемы. Рассмотрение архитектуры указанного процессора со- 
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ставляет основное содержание данного раздела. В настоящее 
время система іАРХ 432 включает также другой процессор — 
интерфейсный (interface processor — IP), служащий для сопря¬ 
жения системы с «внешним миром». Интерфейсный процессор 
расширяет архитектуру системы іАРХ 432, вводя в ее состав 
следующие дополнительные объекты: IP -процессор, ІР-кон- 
текст, ІР-процесс. 

Хотя типы объектов подробно рассматриваются в гл. 17, 
полезно здесь кратко их описать и сравнить с соответствующи¬ 
ми объектами системы SWARD. 

Объект «команды» состоит из последовательности команд, 
обычно представляющей собой подпрограмму. Объект «домен» 
•в общем случае ссылается на ряд объектов «команды» и на дру¬ 
гие объекты, статически связанные с объектами «команды». До¬ 
мен с набором объектов «команды» может быть использован 
для представления структуры, называемой на языке Ада паке¬ 
том; в системе SWARD эквивалентом такой структуры являет¬ 
ся объект «модуль». 

Объект «контекст» создается при обращении к подпрограм¬ 
ме и описывает особенности активации подпрограммы и ее ло¬ 
кальные (внутренние) переменные. Он соответствует объекту 
•«запись активации» системы SWARD. Объект «порт связи» ис¬ 
пользуется для передачи сообщений между процессами. Он 
■схож с объектом «порт» системы SWARD, хотя в каждой си¬ 
стеме установлены свои правила работы с этим объектом. 

Объекты «порт диспетчеризации», «процессор» и «процесс» 
используются для управления процессами и процессорами и 
вместе эквивалентны объекту «процесс-машина» системы 
SWARD. Каждый аппаратно реализуемый процессор описыва¬ 
ется объектом «процессор», а каждый из параллельных потоков 
команд (например, задачи на языке Ада) —объектом «процесс». 
Порт диспетчеризации осуществляет связь между объектами 
этих двух типов. Если конфигурация системы такова, что в ее 
состав входят один порт диспетчеризации, несколько процессо¬ 
ров и процессы, число которых превышает число процессоров, 
то порт диспетчеризации можно рассматривать как очередь 
процессов, готовых к выполнению. Из порта диспетчеризации 
процессы выбираются процессорами независимо (в соответст¬ 
вии со значениями управляющих параметров посредством не¬ 
скольких программ-планировщиков) по мере того, как процес¬ 
соры освобождаются для обработки очередных процессов. 

Объекты «справочник таблиц объектов» и «таблица объек¬ 
тов» используются для перевода потенциальных адресов в фи¬ 
зические адреса памяти. Объект «ресурсы памяти» служит для 
описания областей физической памяти, доступных для распре¬ 
деления объектам. Аналогичные средства существуют и в си- 
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стеме SWARD, где они реализуются аппаратно при создании; 
конкретной модели машины и не описываются как элемент ар¬ 
хитектуры. 

Архитектурой системы іАРХ 432 предусмотрено, что про¬ 
граммы могут порождать свои собственные задаваемые поль¬ 
зователем объекты и снабжать их информацией о типах, с тем; 
чтобы использование объектов было локализовано в определен¬ 
ных частях программы (например использование только про¬ 
граммой обработки типов). Объект, тип которого определяется; 
пользователем, называется объектом расширенного типа, а за¬ 
даваемая пользователем информация о типе содержится в от¬ 
дельном объекте «описание типа». 

Объекты двух типов известны под общим названием «преоб¬ 
разователи», поскольку доступ к ним позволяет выполнять оп¬ 
ределенные операции над объектами (они фактически расширя¬ 
ют возможности потенциальной адресации). Объект «управле¬ 
ние дескриптором» предоставляет возможность создавать объ¬ 
екты, распознаваемые аппаратными средствами (т. е. иденти¬ 
фицируемые как объекты этих средств), а также расширять 
права доступа, отражаемые в потенциальных адресах. Объект 
«аффинаж» позволяет формировать системные объекты, пред¬ 
ставляющие собой подмножества существующих объектов. 

Объект «транспортер» используется объектами некоторых 
других типов для установления связи этих объектов с одной из 
нескольких очередей. Объекты «данные общего назначения» и 
«доступ к данным общего назначения» являются участками 
памяти, не содержащими указания типа хранимой в них инфор¬ 
мации и используемыми для хранения данных (например, зна¬ 
чений переменных какой-либо программы пользователя). 

Основное различие между объектами систем SWARD и 
іАРХ 432 состоит в том, что объекты системы SWARD являют¬ 
ся абстракциями, скрывающими от программиста фактическое 
содержание этих объектов (которое оказывается недоступным 
при программировании), в то время как все объекты системы 
іАРХ 432 находятся в «поле зрения» программ (архитектура 
обеспечивает поразрядное представление всех объектов). След¬ 
ствием этого является то, что объекты системы іАРХ 432 в ос¬ 
новном формируются действиями программы, а не машинными 
командами. Например, для того чтобы создать объект «про¬ 
цесс», программа форматизирует с помощью обычных команд 
обработки данных одну или несколько областей данных в со¬ 
ответствии со структурой объекта «процесс». Затем она сигна¬ 
лизирует машине (при соответствующих полномочиях програм¬ 
мы) о том, что можно начинать рассматривать эту область как 
объект «процесс». Другими словами, объекты системы іАРХ 432 
представляют собой структуры данных с явно заданным описа.- 
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иием, согласно которому аппаратные средства системы выпол¬ 
няют соответствующий набор операций. В то же время средст¬ 
ва операционной системы (спецификаторы типов объектов) 
позволяют расширить ориентацию архитектуры, представляе¬ 
мой совокупностью объектов, трансформируя ее тем самым в 
архитектуру более высокого уровня. 

Набор команд может быть поделен на две категории: 
1) команды, оперирующие объектами определенного типа (та¬ 
кие, как команды SEND, CALL-CONTEXT и READ-PROCESS- 
/ CLOCK), и 2) команды, выполняющие операции над цепочкой 
байтов объекта любого типа (например, MOVE-INTEGER или 
EXTRACT-ORDINAL). 

ПОТЕНЦИАЛЬНАЯ АДРЕСАЦИЯ 

В системе іАРХ 432 используется принцип потенциальной адре¬ 
сации и защиты от несанкционированного доступа. Потенциаль¬ 
ный адрес (дескриптор доступа) относится к объекту и содер¬ 
жит два независимых набора кодов санкционированного досту¬ 
па к нему. Один набор кодов доступа относится к возможности 
юперировать объектами как данными (например, возможность 
проверять и изменять структуру данных, представляющих неко¬ 
торый объект). Другой набор кодов доступа касается возмож¬ 
ности выполнять команды, производящие операции над объ¬ 
ектом, такие, как пересылка объекта в порт. 

Как указывалось в гл. 4, использование потенциальной адре¬ 
сации нуждается в средствах защиты от произвольного форми¬ 
рования потенциальных адресов с последующей манипуляцией 
-ими. В машине с теговой памятью, такой, как SWARD, решение 
этой проблемы достаточно очевидно: потенциальный адрес рас¬ 
сматривают как теговые данные особого типа. 

В системе іАРХ 432 потенциальные адреса защищены пу¬ 
тем использования списков потенциальных адресов. Объекты 
составляются из сегментов , представляющих собой смежные 
области физической памяти. Различают сегменты двух типов: 
сегменты данных, которые могут содержать любые данные, кро¬ 
ме потенциальных адресов, и сегменты доступа, содержимым 
которых могут быть только потенциальные адреса. Сегменты 
доступа используются только для адресации, а обращаться к 
«им можно лишь с помощью нескольких специальных команд, 
что обеспечивает защиту потенциальных адресов в системе 
ІАРХ 432. 

«СБОР МУСОРА» В ПАМЯТИ 

В системе іАРХ 432 предусмотрены средства повторного запро¬ 
са памяти, предназначенной для объектов. Для объектов с ко¬ 
ротким временем существования механизм такого запроса 
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похож на аналогичный механизм системы SWARD. Для объек¬ 
тов же с продолжительным временем существования использу¬ 
ется совершенно другой принцип учета и перераспределения 
памяти. В системе іАРХ 432 участки памяти для объекта мо¬ 
гут запрашиваться как из области, выделенной для процесса 
(объект относительно короткого времени существования), так 
и из области глобальных ресурсов памяти системы (объект 
длительного времени существования). Объекты с коротким вре¬ 
менем существования, хотя и связаны с создаваемым контекстом 
(активацией подпрограммы), уничтожаются автоматически. 
В то же время в системе SWARD они связаны с процесс-маши¬ 
ной. Если в системе SWARD требуется явное уничтожение объ¬ 
ектов продолжительного времени существования с помощью 
команды DESTROY, причем не исключена возможность потери 
объектов, то в системе іАРХ 432 предусмотрены средства, поз¬ 
воляющие программе «сбора мусора», выполняемой параллель¬ 
но с другими программами, выявлять области памяти, относя¬ 
щиеся к неиспользованным объектам, и включать их в пул сво¬ 
бодной памяти. Таким образом, в системе іАРХ 432 действует 
принцип неявного уничтожения объектов, возможность адреса¬ 
ции к которым утеряна. (Неадресуемые объекты перед уничто¬ 
жением обычно обрабатываются так называемым спецификато¬ 
ром типа объекта.) 

ОБЛАСТИ САНКЦИОНИРОВАННОГО ДОСТУПА 

В момент вызова объекта «команда» создается объект «кон¬ 
текст». Помимо выполнения других функций, объект «кон¬ 
текст» определяет для объекта «команда» сферу адресации, 
в которую входят: 1) локальные переменные; 2) объекты, 
к которым обращается объект «домен», связанный с объектом 
«команда» (например, объекты, содержащие глобальные пере¬ 
менные для программы, константы и статические переменные 
для домена); 3) «сообщение», передаваемое из вызывающей 
подпрограммы. (Типичной является ситуация, когда сообщение 
является сегментом доступа, содержащим потенциальные ад¬ 
реса фактических параметров.) Таким образом, имеется воз¬ 
можность достаточно точно управлять механизмом внешних 
ссылок из подпрограмм (например, подпрограмма не может 
свободно обращаться к локальным переменным другой под¬ 
программы). 

АВТОМАТИЧЕСКОЕ 
УПРАВЛЕНИЕ ПОДПРОГРАММАМИ 

Система 432 содержит механизм обращения к подпрограммам, 
хотя и не такой развитый, как аналогичный механизм системы 


5-429 
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SWARD. Для вызова подпрограммы с передачей параметров в 
сегмент доступа необходимо вставить потенциальные адреса 
формальных или фактических параметров и выполнить коман¬ 
ду CALL-CONTEXT-WITH-MESSAGE, передавая сегмент до¬ 
ступа в качестве сообщения. При этом создается объект «кон¬ 
текст» с памятью, выделенной для локальных переменных. 
В отличие от системы SWARD здесь формирование списка па¬ 
раметров и инициализация значений локальных переменных не 
являются составной частью механизма обращения к подпро¬ 
граммам и должны выполняться прикладными программами. 

ОБЪЕКТЫ «ПРОЦЕСС» И «ПРОЦЕССОР» 

В модели памяти іАРХ 432 параллельно выполняемые процес¬ 
сы и аппаратно реализованные процессоры представлены в ви¬ 
де отдельных объектов. Тем самым достигается значительная 
гибкость описания функционирования системы: все манипуля¬ 
ции, которые могут быть выполнены над объектом, возможно 
произвести над процессом или процессором. Например, мож¬ 
но принять меры для защиты процессов или процессоров от не¬ 
санкционированного доступа посредством потенциальных адре¬ 
сов, модифицировать их состояние путем изменения данных в 
соответствующем объекте, проверить состояние процесса или 
процессора как соответствующего объекта системы или пере¬ 
слать их как сообщения. 

В системе SWARD понятия процесса и процессора обобщен¬ 
но отражены в абстрактном понятии процесс-машина. В ре¬ 
зультате связь между физическими процессорами и процесс- 
машинами (в частности, распределение процесс-машин между 
процессорами), не находит никакого отражения в программном 
обеспечении и зависит от конкретной машинной реализации си¬ 
стемы. В системе іАРХ 432 эти связи становятся явными и по¬ 
этому могут контролироваться средствами программного обес¬ 
печения. Здесь предусмотрены эффективные и в высшей степе¬ 
ни гибкие средства контроля за распределением процессов 
между процессорами. В общем случае диспетчеризация низкого 
уровня (при операциях длительностью не более нескольких мил¬ 
лисекунд) выполняется аппаратно, но управление последова¬ 
тельностью выполнения процессов осуществляется на более вы¬ 
соком уровне — операционной системой, определяющей и изме¬ 
няющей значения управляющих параметров в объектах «про¬ 
цесс». Такие параметры позволяют выполнять планирование, 
имеющее более общий, всеобъемлющий характер, чем то, кото¬ 
рое достигается аппаратными средствами. 

Как подчеркивается в гл. 4, в системе іАРХ 432 имеется це¬ 
лый набор механизмов управления, позволяющих средствами 
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программного обеспечения реализовать большое разнообразие 
типов поведения вычислительной системы. 

•СРЕДСТВА ПЕРЕДАЧИ - ПРИЕМА СООБЩЕНИИ 

Порт связи является объектом, посредством которого процесс 
может посылать отдельные сообщения другому процессу. Роль 
сообщения может выполнять объект системы (например, про¬ 
цесс), набор потенциальных адресов (сегмент доступа), им мо¬ 
гут быть и данные (в частности, сегмент данных). 

В отличие от системы SWARD средства передачи—приема 
рассматриваемой здесь системы работают асинхронно с сооб¬ 
щениями, поставленными в очередь к портам. Обслуживание 
может выполняться либо по принципу «первый поступил — пер¬ 
вый обработан», либо в соответствии с системой приоритетов — 
обслуживается объект с наивысшим приоритетом. Предусмотрен 
также механизм отбора среди входов (surrogate mechanism), 
позволяющий организовать для процесса ожидание поступления 
сообщения от любого из некоторого множества портов. Это 
средство похоже на механизм, реализованный оператором SE¬ 
LECT в языке Ада. Применительно к системе іАРХ 432 тради¬ 
ционное понятие прерывания не существует. Прерывания обра¬ 
батываются во внешней системе ввода-вывода и через интер¬ 
фейсный процессор могут инициировать события в системе (на¬ 
пример, пересылку сообщения). 

обработка ошибок 

Как и в системе SWARD, выявленные машиной особые ситуа¬ 
ции принято называть ошибками. Обнаружение ошибки застав¬ 
ляет машину передать выполнение команды специальным про¬ 
граммным средствам обработки ошибок, которые могут быть 
связаны с тем объектом «команды», в котором произошла 
ошибка. Машина формирует подробную информацию о встре¬ 
тившейся ошибке. 

В отличие от системы' SWARD в системе іАРХ 432 преду¬ 
смотрены отдельные средства обработки как ошибок процес¬ 
сов, так и ошибок процессоров. При обработке ошибок процес¬ 
са объектом анализа, помимо процесса, в котором обнаружена 
ошибка, обычно являются и другие компоненты системы, на¬ 
пример операционная система. При появлении в некотором про¬ 
цессе такой ошибки, процесс (как объект) отсылается к спе¬ 
циальному порту связи (называемому портом ошибок, который 
может быть входным портом специального процесса в опера¬ 
ционной системе —программы обработки ошибок). Точно так 
же при появлении ошибки процессора (например, при аппарат¬ 
ных ошибках) процессор подключается к специальному порту 

5 * 
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диспетчеризации, называемому портом диагностики, являюще¬ 
муся входным для специального диагностического процесса опе¬ 
рационной системы. 

БОЛЬШОЙ РАЗМЕР АДРЕСНОГО ПРОСТРАНСТВА 

Система іАРХ 432 располагает обширным адресным прост¬ 
ранством в отношении как размера физически реализуемой па¬ 
мяти, так и количества объектов, допустимых к использованию. 
В соответствии с возможностями средств кодирования потенци¬ 
альных адресов максимальное количество адресуемых объек¬ 
тов может равняться 2 24 , точнее, такое количество сегментов 
может иметь система іАРХ 432 (см. гл. 17). 

Максимальный размер сегмента может достигать 65 536 
байт (исключением являются сегменты «команды», размер ко¬ 
торых ограничен 8192 байт). Итак, при обращении к объектам 
посредством потенциальных адресов максимальный размер ад¬ 
ресуемого пространства равен 2 40 байт; при этом максимальный 
размер адресуемой физической памяти составляет 2 24 байт. 

ГИБКОСТЬ АДРЕСАЦИИ К ОПЕРАНДАМ 

Архитектуру системы іАРХ 432 можно охарактеризовать как 
трехадресную с пересылкой данных типа «память-память»; про¬ 
граммы не имеют прямого доступа к регистрам. Возможность 
использования разнообразных форм адресов операндов предо¬ 
ставляет широкий выбор различных типов косвенной адресации 
и позволяет обращаться к элементам данных векторного типа. 
Проще говоря, адреса операндов в команде содержат смеще¬ 
ния относительно начала объекта и информацию, позволяющую 
определить местоположение объекта и задаваемую обычно в 
виде индекса к таблице потенциальных адресов. 

Интересным расширением возможностей адресации к опе¬ 
рандам является наличие необязательного к использованию 
стека операндов с возможностью обращения за любым операн¬ 
дом команды в стек вместо обращения за данными к объекту 
посредством задания их смещения относительно начала этого 
объекта. Один из сегментов, входящий в объект «контекст», 
и является стеком операндов. Присваивая битам машинной 
команды определенные значения, можно специфицировать эту 
команду, например, следующим образом: «Второй операнд 
команды —это содержимое вершины стека, а не ссылка на объ¬ 
ект». Стек операндов, один на контекст (активацию), является 
сегментом данных в памяти, хотя в рассматриваемой версии 
системы 16 бит, которые должны располагаться на вершине 
стека, хранятся в одном из регистров процессора. 
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РАСШИРЕННЫЕ ВОЗМОЖНОСТИ ВЫПОЛНЕНИЯ 
ОПЕРАЦИИ с плавающей точкой 

Возможности выполнения операций над числами с плавающей 
точкой в системе іАРХ 432 весьма широкие даже по сравнению 
с возможностями больших ЭВМ. Предусмотрено три типа пред¬ 
ставления чисел с плавающей точкой: посредством 32, 64 и 
80 бит. Последний тип записи позволяет представлять числа 
величиной до 1,2-ІО 4932 . 

С помощью подпрограммы можно управлять способом 
округления (до ближайшего значения, до ближайшего больше¬ 
го, до ближайшего меньшего или до нуля в младшем разряде), 
точностью выполнения операций с плавающей точкой и обра¬ 
боткой неточных результатов (как при наличии ошибок, так и 
при их отсутствии). 

КОМПОНЕНТЫ СИСТЕМЫ 
И ЕЕ ВОЗМОЖНАЯ КОНФИГУРАЦИЯ 

В рассматриваемую версию системы іАРХ 432 входят компо¬ 
ненты трех типов. Два из них —43201 и 43202 — составляют 
процессор общего назначения. Модуль 43201 выполняет выбор¬ 
ку и декодирование команд машины, а большая часть операций 
по адресации и арифметических операций реализуется модулем 
43202. Оба модуля тесно связаны друг с другом 16-разрядной 
шиной с микропрограммным управлением. Оба устройства по¬ 
строены на программируемых логических матрицах; использу¬ 
ется большое разнообразие микропрограмм. 

Модуль 43203 — это интерфейсный процессор, выполняющий 
роль канала ввода-вывода. Он является средством расширения 
набора объектов и команд системы іАРХ 432 и дает возмож¬ 
ность программам устанавливать связи с другими подсистема¬ 
ми через внешний интерфейс. Интерфейсный процессор позво¬ 
ляет процессору ввода-вывода выполнять подмножество команд 
іАРХ 432 по передаче данных в память и из памяти системы че¬ 
рез четыре назначаемых окна памяти'). С его помощью об¬ 
щие принципы защиты данных в системе іАРХ 432 распростра¬ 
няются и на уровень внешнего интерфейса. Так, внешние 
устройства не могут записывать данные в произвольные обла¬ 
сти памяти, а только в специальные объекты, создаваемые со¬ 
ответствующими процессами системы. 


11 Речь идет о размещенных в интерфейсном процессоре программируемых 
ассоциативных блоках памяти, позволяющих программным путем осущест¬ 
влять отображение области адресов подсистемы ввода-вывода в адреса си¬ 
стемы іАРХ 432. — Прим. ред. 
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Рис. 16.2. Пример конфигурации системы іАРХ 432. 


На рис. 16.2 изображена конфигурация большой системы 
іАРХ 432 с четырьмя процессорами общего назначения (GDP) 
и тремя интерфейсными процессорами (IP). Сопряжение с па¬ 
мятью осуществляется через специальную шину, ориентирован¬ 
ную на передачу пакетов информации. При выполнении каж- 



ОСНОВНЫЕ ПРИНЦИПЫ РАБОТЫ МИКРОПРОЦЕССОРА ІАРХ 432 71 


дой операции над данными из памяти может быть передано от 
1 до 6 байт. 

При работе нескольких процессоров особое внимание следу¬ 
ет уделять согласованию обращения к памяти во избежание их 
наложений. При наличии только одной шины доступа к памяти 
целесообразно использование не более пяти процессоров GDP. 
Дальнейшее увеличение числа этих процессоров вследствие кон¬ 
куренции за доступ к общей памяти вносит несущественный 
вклад в эффективность работы системы. Система с единствен¬ 
ной шиной доступа и пятью процессорами GDP имеет прибли¬ 
зительно такую же скорость выполнения команд, как и систе¬ 
ма с тремя автономными процессорами GDP. При наличии 
большого числа процессоров требуется использование несколь¬ 
ких шин доступа, коммутируемых, например, матричными пере¬ 
ключателями. 
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ГЛАВА 17 

ПРОЦЕССОР ОБЩЕГО НАЗНАЧЕНИЯ 
ІАРХ 432 

В этой главе описывается архитектура процессора общего на¬ 
значения іАРХ 432, причем рассмотрение ведется в основном 
с точки зрения организации памяти системы. Материал изла¬ 
гается последовательно, от определения понятий нижнего уров¬ 
ня иерархии системы — сегментов и типов данных — до описа¬ 
ния элементов самого высокого уровня — объектов. Далее об¬ 
суждается наиболее сложная по структуре и трудная для вос¬ 
приятия характеристика рассматриваемой архитектуры — адре¬ 
сация. В заключение данной главы описываются типы объек¬ 
тов, техника обработки ошибок и другие средства системы. 
Форматы команд и соответствующие операции рассматривают¬ 
ся в гл. 18. 

СЕГМЕНТЫ И ТИПЫ ДАННЫХ 

Для средств управления памятью и адресации системы іАРХ 432 
основной единицей манипулирования является не объект, а сег¬ 
мент. Объекты обычно состоят из нескольких сегментов. Сег¬ 
мент— это непрерывный участок физически реализованной па¬ 
мяти размером от 1 до 65 536 байт. Перечислим пять основных 
понятий, характеризующих сегменты: 

1) базовый адрес, являющийся 24-битовым адресом первого 
байта сегмента; 

2) длина (1—65 536 байт); 

3) базовый тип (сегментами базового типа являются сегмен¬ 
ты данных и сегменты доступа); 

4) системный тип (сегмент такого типа используется для 
определения объекта, например объекта «контекст» или «про¬ 
цесс», частью которого является этот сегмент); 

5) дескриптор памяти в таблице объектов, содержащий атри¬ 
буты сегмента (физический адрес, длину, тип) и используемый 
для преобразования потенциальных адресов. 
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Различие между сегментами доступа и данных заключается 
в том, что первые могут содержать только потенциальные ад¬ 
реса (дескрипторы доступа), а вторые —все, кроме потенци¬ 
альных адресов. Машина не допускает использования сегмента 
доступа в качестве данных (регистрируется ошибка) или ка¬ 
кой-либо части сегмента данных в качестве потенциального 
адреса. 

Следствием этого является то обстоятельство, что, напри¬ 
мер, для записи на языке Ада фрагмента 

type LIST _ ELEM is 

record 

CHAIN : access LIST_ELEM; 

VALUE : INTEGER; 

NAME : STRING(1. . 16); 
end record; 

возникает необходимость в использовании нескольких сегмен¬ 
тов: сегмента данных для размещения значений переменных 
VALUE и NAME и представляющем эту запись сегмента досту¬ 
па для размещения потенциального адреса CHAIN и потенци¬ 
ального адреса упомянутого сегмента данных. 

При переходе от понятия «сегмент» к другим понятиям, ис¬ 
пользуемым при описании системы іАРХ 432, необходимо пом¬ 
нить следующее: 

1. Все, принадлежащее модели памяти системы іАРХ 432, 

описывается в терминах «сегменты»: переменные в програм¬ 
ме— это строки байтов, смещенные на некоторую определен¬ 
ную величину относительно начала сегмента и в нем располо¬ 
женные; объекты — это структуры данных одного или несколь¬ 
ких сегментов (приведенная выше запись LIST _ ELEM _ 

двухсегментный программно-определяемый объект). 

2. Потенциальные адреса служат по сути дела для обраще¬ 
ния к сегментам, а не к объектам. Однако, как и в рассмотрен¬ 
ном выше примере, многосегментные объекты включают в свой 
состав корневой сегмент доступа, содержащий ссылки на дру¬ 
гие сегменты. Часто потенциальный адрес такого корневого сег¬ 
мента называют потенциальным адресом объекта. 

Поскольку система отличает сегменты доступа от сегмен¬ 
тов данных, а также в связи с тем, что сегменты доступа мо¬ 
гут содержать только потенциальные адреса, можно утверж¬ 
дать, что іАРХ 432 является в определенном смысле машиной 
с теговой памятью, располагающей теговыми данными двух ти¬ 
пов: строками байтов и векторами потенциальных адресов. При 
этом, как и можно было ожидать, рассматриваемая система 
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допускает различную интерпретацию строки байтов. Прежде 
чем перейти к этому "Вопросу, отметим, что упомянутая интер¬ 
претация, т. е. описание типов строк байтов, совпадает по 
смыслу с описанием типов данных архитектуры машин с тего¬ 
вой организацией памяти, например такой, как SWARD. Рас¬ 
смотрение типов данных системы іАРХ 432 по сути дела сво¬ 
дится к рассмотрению набора команд. Список и формат типов 
данных приведены на рис. 17.1. Так называемые символьные 
данные занимают 1 байт памяти и используются для пред¬ 
ставления целого числа без знака, символа (соответствующего 
одному из стандартных символов, представляемых в коде 
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Рис. 17.1. Типы данных системы ІАРХ 432. 
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ASCII) или логической величины (для представления которой 
используется только бит младшего разряда). Имеются два ти¬ 
па данных, именуемых порядковые числа и являющихся двоич¬ 
ными целыми числами без знака. Они часто используются в ка¬ 
честве значений индексов, содержимого счетчиков или строк би¬ 
тов. Имеются также два типа данных целого типа, представ¬ 
ляемых в традиционной форме в виде дополнительных кодов. 
Числовые данные в форме с плавающей точкой представлены 
тремя типами, которые отличаются не только точностью опи¬ 
сания мантиссы, но и величиной порядка (задаваемого со сме¬ 
щением 127, 1023 или 16 383). Знак такого числа задается со¬ 
держимым двоичного знакового разряда. Первые два типа ве¬ 
щественных чисел (длиной 32 и 64 бит) используют такую 
форму нормализованного представления мантиссы, при кото¬ 
рой ее ведущий значащий бит находится за разрядной сеткой. 
Благодаря этому вещественные числа короткой или нормаль¬ 
ной длины представляются с точностью на один двоичный раз¬ 
ряд более высокой, чем точность при традиционных формах 
представления чисел с плавающей точкой. Если поле порядка 
вещественных чисел любого из трех рассматриваемых типов со¬ 
держит единицы во всех двоичных разрядах, это указывает на 
отсутствие числа (так называемое представление NaN — not 
a number). 

Все арифметические операции с плавающей точкой процес¬ 
сор выполняет над числами, представленными в виде так на¬ 
зываемых временных данных вещественного типа. Как упомина¬ 
лось в гл. 16, объект «контекст», связанный с активацией под¬ 
программы, содержит спецификацию требуемых характеристик 
операций с плавающей точкой (параметры округления, точ¬ 
ность представления результатов, действия при отсутствии тре¬ 
буемого результата). 

Система іАРХ 432 имеет в своем распоряжении данные еще 
одного типа, называемые дескриптором доступа, или потен¬ 
циальным адресом. Дескриптор доступа используется как сред¬ 
ство обращения к сегменту и определения прав доступа к по¬ 
следнему. Формат дескриптора доступа предполагает наличие 
следующих полей: индекса справочника таблиц объектов, ин¬ 
декса сегмента (используемого для определения адреса деск¬ 
риптора объекта, адресуемого данным дескриптором и описы¬ 
ваемого более подробно в последующих разделах), флагов прав 
объекта, флагов прав системы, хип-флага (heap flag) и флага 
готовности. Последний указывает, можно ли использовать дан¬ 
ный дескриптор доступа для адресации. 

Различие между «правами объекта» и «системными права¬ 
ми» заключается в том, что флаги прав объекта указывают, ка¬ 
кие операции можно выполнить над сегментом, рассматривая 
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его просто как сегмент данных или доступа, в то время как фла¬ 
ги прав системы указывают, какие операции можно выполнить 
над сегментом как над системным объектом (или корневым сег¬ 
ментом доступа). «Права объектов» представлены в дескрип¬ 
торе доступа следующими флагами: чтения, записи и исключе¬ 
ния, или удаления (возможность удалить сам дескриптор до¬ 
ступа или записать на его месте другую информацию). Кон¬ 
кретная интерпретация флагов прав системы зависит от типа 
адресуемого объекта. Назначение хип-флага, связанного с ра¬ 
ботой системы управления памятью, описывается в следующем 
разделе. 

СЕГМЕНТЫ И ОБЪЕКТЫ 

Система іАРХ 432 базируется на принципе наложения на сег¬ 
менты масок, имеющих специальные, заранее определенные 
форматы, с целью создания объектов и задания набора ма¬ 
шинных операций над этими объектами. Объектом может быть 
одиночный сегмент, набор взаимосвязанных сегментов (обыч¬ 
но использующих корневой сегмент доступа для связи с дру¬ 
гими сегментами) или часть сегмента, называемая аффинажем 
(refinement) . 

Главное отличие архитектуры системы іАРХ 432 от архитек¬ 
туры системы SWARD состоит в том, что пользователю первой 
системы доступна структура объектов, в то время как для поль¬ 
зователя второй системы объекты — это некоторые абстракт¬ 
ные понятия, а структура этих объектов имеет конкретное во¬ 
площение только при реализации машины. Архитектуры этих 
систем различаются также тем, что все объекты системы 
іАРХ 432 (за исключением объекта «контекст») конструиру¬ 
ются в соответствии с алгоритмами программ, а в системе 
SWARD объекты создаются путем выполнения машинных опе¬ 
раций. В системе SWARD анализ состояния объекта осущест¬ 
вляется путем выполнения машинной команды, например 
команды DESCRIBE-CAPABILITY. В системе іАРХ 432 подоб¬ 
ная цель достигается путем анализа данных внутри объекта, 
что не обязательно предполагает «осведомленность» программ 
системы іАРХ 432 о структуре объектов; к обсуждению этого 
вопроса мы еще вернемся. 

Для иллюстрации сказанного выше обратимся к объекту 
«порт», схематически изображенному на рис. 17.2 (порты дис¬ 
петчеризации и связи имеют одинаковую структуру). Порт со¬ 
стоит из сегмента доступа и сегмента данных. (Потенциальный 
адрес, которым является дескриптор доступа, называют потен¬ 
циальным адресом объекта «порт»). Порт может создаваться 
следующим образом. Сначала формируются два сегмента. По- 
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скольку они являются частью системного объекта, т. е. объек¬ 
та, определенного системой, а не пользователем, для их созда¬ 
ния используются не обычные команды формирования сегментов 
(CREATE-ACCESS-SEGMENT и CREATE-DATA-SEGMENT) , 
а команда CREATE-TYPED-SEGMENT. (Как следует из рас¬ 
сматриваемой в дальнейшем проблемы защиты потенциальных 
адресов, эта команда не может быть использована односто¬ 
ронне, т. е. без взаимного обращения к ней адресата.) За¬ 
тем полям обоих сегментов присваиваются начальные значе- 
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Рис. 17.2. Представление объекта «порт». 


ния в соответствии с заданным исходным состоянием. Это осу¬ 
ществляется посредством обычных команд манипуляции данны¬ 
ми, причем в сегмент доступа будет помещен дескриптор досту¬ 
па (ДД) для обеспечения обращения к сегменту данных. 

Оставим на некоторое время обсуждение специфики объ¬ 
ектов типа «порт» и сделаем несколько общих замечаний отно¬ 
сительно сегментов на основании анализа рис. 17.2. Прежде все¬ 
го отметим, что у сегментов нет заранее установленных, фикси¬ 
рованных размеров. Это же справедливо для некоторых, но не 
для всех объектов. Порт представляет собой очередь: порт 
связи — очередь сообщений или принимаемых процессов, порт 
диспетчеризации — очередь процессов или не занятых выполне¬ 
нием операций процессоров. Верхняя часть адресного простран¬ 
ства обоих сегментов (т. е. часть с наибольшими значениями 
адресов) используется для хранения информации об очередях. 
Благодаря этому программа, создающая порт, имеет возмож¬ 
ность управлять размером очереди. В некоторых объектах (но 
не в рассматриваемом случае) определенное функциональное 
назначение предписывается только нижней части сегментов 
(т. е. областям памяти с наименьшими номерами), так что по- 
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является возможность использования оставшейся части сегмен¬ 
та (сегментов) программ для размещения их собственной ин¬ 
формации, если имеется такая необходимость. 

Следует отметить также наличие в сегменте данных (рищ 
17.2) поля, называемого блокировка объекта (object lock). Это 
поле используется как программным обеспечением системы 
(для синхронизации использования объекта одновременно про¬ 
текающими процессами), так и аппаратными средствами (для 
предотвращения попыток одновременного обновления несколь¬ 
кими процессорами информации в одном и том же объекте). 

Напомним, что в дескрипторе доступа имеется поле «права 
системы». Интерпретация содержимого этого поля зависит от 
типа адресуемого объекта. Так, для порта связи первый бит 
указывает, разрешается ли посылать в этот порт сообщение; 
второй бит сигнализирует, можно ли принимать сообщение иа 
данного порта; третий бит не используется. 

СПЕЦИФИКАТОРЫ ТИПОВ ОБЪЕКТОВ 

Хотя формат объекта «порт» определяется при описании архи¬ 
тектуры системы и маловероятно внесение изменений в его оп¬ 
ределение, представляется естественным лишить программы 
информации о формате такого объекта. Предпочтительнее та¬ 
кое решение, когда программы манипулируют портом как аб¬ 
страктным понятием, для выполнения операций над которым 
задан набор некоторых функций. Некоторые из этих функций 
реализуются отдельными машинными командами (в частности, 
командами SEND, RECEIVE), другие — программными моду¬ 
лями (например, подпрограммой CREATE — PORT). 

Тогда естественно предположить наличие в системе для объ¬ 
екта каждого типа (включая объекты, тип которых определя¬ 
ется программистом) так называемого программного специфи¬ 
катора типа объекта (type manager). Последний представляет 
собой набор взаимосвязанных подпрограмм, реализующих внут¬ 
реннюю структуру объекта определенного типа путем обеспе¬ 
чения выполнения над объектом операций в соответствии с его 
типом. При этом для программ, выполняемых системой, объ¬ 
ект представляется неким «черным ящиком» — абстрактным по¬ 
нятием, конкретная структура которого неизвестна. Спецификато¬ 
ры системных объектов обычно являются частью операционной 

системы. Так, подпрограмма CREATE — COMMUNICATION _ 

PORT была бы подпрограммой операционной системы. Делап 
«невидимой» для программ пользователя информацию о фор¬ 
мате объекта «порт», подобная подпрограмма в результате об¬ 
ращения к ней создает дескриптор доступа с полным набором 
разрешенных форм доступа (прав) системы, но не объекта. 
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Функции спецификаторов типов объектов описываются в не¬ 
скольких последующих разделах, поскольку в системе іАРХ 432 
имеются мощные программные средства для реализации этих 
функций. 

АФФИНАЖ 

Аффинаж —это объект, представляющий собой последователь¬ 
ность смежных байтов в пределах некоторого сегмента. Не¬ 
сколько иначе такой объект можно рассматривать как дескрип¬ 
тор доступа к некоторой части сегмента, но не ко всему сег¬ 
менту. Положим, имеется сегмент данных, содержащий локаль¬ 
ные переменные активной подпрограммы. Пусть при этом тре¬ 
буется создать дескриптор доступа к какой-либо одной пере¬ 
менной внутри сегмента. Возможна ситуация, когда эта 
локальная переменная — один из нескольких фактических пара¬ 
метров, подлежащих передаче в подпрограмму посредством ад¬ 
реса. Желательно поместить дескрипторы доступа к конкрет¬ 
ным параметрам в сегмент доступа и передать последний, на¬ 
зываемый сообщением, вызываемой подпрограмме. При таком 
решении дескрипторы доступа будут адресоваться к аффина- 
жам сегмента данных и могут быть созданы командой CREATE- 
GENERIC-REFINEMENT, которая по заданным дескриптору 
доступа к сегменту, смещению и длине создает соответствую¬ 
щий дескриптор доступа к подпространству (части) сегмента. 
Следовательно, эта команда подобна команде COMPUTE- 
CAPABILITY системы SWARD. 

Отметим, что аффинажы необходимы для организации до¬ 
менов— небольших областей адресного пространства, защи¬ 
щенных от несанкционированного доступа (см. гл. 4). Следует 
помнить, что дескриптор доступа к аффинажу нельзя исполь¬ 
зовать для обращения к другим данным того же сегмента, по¬ 
скольку механизм адресации обращается с аффинажем как с 
отдельным сегментом (т. е. у него имеются базовый адрес и 
длина). В действительности же при наличии дескриптора до¬ 
ступа к аффинажу существует способ получения дескриптора 
доступа ко всему сегменту. Для этой цели используется коман¬ 
да RETRIEVE-REFINEDOBJECT, которая, однако, может быть 
защищена от несанкционированного доступа. 

АДРЕСАЦИЯ 

Система адресации, т. е. средства обращения команд к своим 
операндам, — это наиболее сложное и трудное для понимания 
понятие архитектуры системы іАРХ 432. Сложность системы 
адресации обычно представляет интерес только для разработ- 
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Рис. 17.3. Уровень наибольшей абстракции 
адресации к данным. 

чиков компиляторов. Поэтому знакомство с адресацией следует 
осуществлять постепенно, переходя от одного уровня ее струк¬ 
туры к другому. Начав с уровня наибольшей абстракции, мы 
перейдем потом к уровню, описывающему детали структуры ад¬ 
ресации. 

С позиций уровня наибольшей абстракции обращение ма¬ 
шинных команд к одному или нескольким операндам внутри 
сегмента соответствует схематическому представлению, приве¬ 
денному на рис. 17.3. Поле обращения к данным (адреса опе¬ 
ранда) команды содержит информацию, используемую для оп¬ 
ределения местоположения сегмента, а также информацию о 
смещении, предназначенную для определения положения кон¬ 
кретных данных на границе байтов внутри сегмента. Команды 
заранее не «привязаны» к конкретным сегментам и физическим 




Рие. 17.4. Адресация посредством таблицы объектов. 





Рис. 17.5. Структура двухуровневой таблицы объектов. (Обычно в системе 
предусмотрен только один справочник таблиц объектов; адрес базы 
известен всем процессорам посредством объекта «процессор».) 


адресам сегментов. Более того, имеется много уровней косвен¬ 
ных взаимосвязей между командой и ее операндом. 

Другим, менее высоким уровнем абстракции структуры адре¬ 
сации является адресация посредством таблицы объектов (рис. 
17.4). Каждый сегмент располагает ассоциативной памятью, 
представленной дескриптором объекта в таблице объектов. Этот 
дескриптор определяет физический адрес сегмента, его длину, 
базовый тип (сегмент данных или сегмент доступа) и тип его 
объекта. Поскольку максимальное число сегментов равно 2 24 , 
таблица объектов имеет двухуровневую структуру (рис. 17.5). 
Объект «справочник таблиц объектов» — это таблица объектов 
таблиц объектов. Каждая таблица объектов описывается дес¬ 
криптором объекта в справочнике таблиц объектов. 

Для адресации сегмента используются два индекса. Пер¬ 
вый индекс—12-битовый индекс справочника — указывает на 
элемент в справочнике таблиц объектов, который является 
ссылкой на таблицу объектов. Второй индекс—12-битовый ин¬ 
декс сегмента — указывает на дескриптор объекта в этой таб¬ 
лице объектов, который содержит ссылку на искомый сегмент. 
Согласно представленному на рис. 17.1 описанию дескриптора 
доступа (потенциального адреса), в нем имеются индексы 
справочника и сегмента. Следовательно, ссылка на данные в 
команде является обращением к дескриптору доступа и содер¬ 
жит информацию о смещении. 


6—429 
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Обычно в системе имеется только один справочник таблиц 
объектов. Количество этих таблиц определяется программным 
обеспечением: обычно операционная система создает одну таб¬ 
лицу объектов для каждого активного процесса. 

Рис. 17.6 иллюстрирует еще несколько уровней структуры 
адресации команды к своим операндам. Поле обращения к дан¬ 
ным должно содержать ссылку на дескриптор доступа и вели¬ 
чину смещения (адресуемых данных относительно начала сег¬ 
мента). Выбор дескриптора доступа осуществляется посредст¬ 
вом ссылки, состоящей из двух частей: селектора и индекса 
входного сегмента доступа (ВСД). 

Объект «контекст» — один на каждую активацию подпро¬ 
граммы— определяет то адресное пространство, которое «окру¬ 
жает» подпрограмму, т. е. пространство, с которым она взаи¬ 
модействует. В любой момент времени может быть не более 
четырех сегментов доступа, которые содержат ДД, непосредст¬ 
венно используемые командами. Эти сегменты называются 



Рис. 17.6. Путь от обращения к операнду в команде до местоположения 
операнда. 
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входными сегментами доступа, поскольку именно они в дан¬ 
ный момент используются при адресации. 

Одним из входных сегментов доступа, обозначаемым ВСД О* 
является сегмент, выбираемый селектором ВСД со значением 6 
и являющийся корневым сегментом доступа самого контекста. 
Другими тремя из четырех ранее упомянутых сегментов досту¬ 
па являются любые сегменты, адресуемые самим объектом 
«контекст». Для программного обеспечения возможно принятие 
следующего соглашения: селектор 0 обращается к сегменту до¬ 
ступа к контексту, селектор 1 — к сегменту доступа, обращаю¬ 
щемуся к общим, или глобальным, данным, селектор 2 — к сег¬ 
менту доступа к текущему сообщению (например, списку па¬ 
раметров), селектор 3 предназначен для общего использования. 

На данной стадии анализа адресации можно утверждать,, 
что имеется по крайней мере семь уровней косвенных взаимо¬ 
связей между командой и ее операндом, поскольку по крайней 
мере дважды необходимо пользоваться справочником таблиц 
объектов: один раз для извлечения данных из контекста с пе¬ 
редачей в выбранный входной сегмент доступа и другой раз 
для извлечения из выбранного дескриптора доступа с переда¬ 
чей в сегмент данных. Перечислим действия, выполняемые на 
указанных уровнях: 

1) селектор ВСД в команде выбирает ДД для входного сег¬ 
мента доступа; 

2) индекс справочника из этого ДД выбирает дескриптор 
объекта из справочника таблиц объектов; 

3) дескриптор объекта выбирает таблицу объектов, которая 
совместно с индексом сегмента из ДД позволяет выбрать сег¬ 
мент; последний подлежит использованию в качестве входного 
сегмента доступа; 

4) индекс ВСД из команды выбирает ДД из этого входного 
сегмента доступа; 

5) индекс справочника из этого ДД выбирает дескриптор 
объекта из справочника таблиц объектов; 

6) дескриптор объекта выбирает таблицу объектов, которая 
совместно с индексом сегмента из ДД позволяет выбрать иско¬ 
мый сегмент; 

7) смещение из команды обеспечивает выбор искомых дан¬ 
ных из этого сегмента. 

Далее будет указано, что селектор ВСД и индекс не всегда 
размещаются непосредственно в команде, а это приводит к об¬ 
разованию еще одного или двух дополнительных уровней взаи¬ 
мосвязи команды со своим операндом. 

Наличие указанных косвенных взаимосвязей обычно не вле¬ 
чет за собой дополнительные временные издержки при адреса¬ 
ции. Это объясняется следующими двумя обстоятельствами. 

€• 
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I Адрес I 

I операнда \ 


Шращение I 
\к данным 


Во-первых, локальные пе¬ 
ременные как наиболее 
часто адресуемые данные 
обычно расположены в сег¬ 
менте данных, связанном с 
объектом «контекст». Одно¬ 
го, а не двух проходов по 
таблице объектов обычно 
достаточно для определе¬ 
ния местоположения этих 
данных. Во-вторых, каждый 
процессор имеет несколько 
ассоциативных запоминаю¬ 
щих устройств, размещенных на том же кристалле, на котором 
находится сам процессор. А как будет описано в гл. 18, процес¬ 
сор хранит в этой памяти информацию, полученную от дескрип¬ 
торов доступа и объекта, которые использовались последними. 
Поэтому процессор часто может обходиться без выполнения 
стандартных этапов адресации. 


Рис. 17.7. Два типа обращения к 
операндам. 


АДРЕСАЦИЯ ОПЕРАНДОВ КОМАНД 

На рис. 17.6 показана последовательность адресации системы 
іАРХ 432, начиная с получения из команды значения селекто¬ 
ра ВСД, индекса ВСД и смещения. Однако это только вторая 
часть структуры адресации; ее первая часть связана с получе¬ 
нием исходной информации для описанной второй части. Прин¬ 
ципы формирования адреса операнда в команде схематически 
изображены на рис. 17.7. Поле адреса операнда в команде мо¬ 
жет содержать обращение либо к данным в сегменте, либо к 
данным на вершине стека операндов. Каждый объект «кон¬ 
текст» располагает связанным с ним сегментом данных, назы¬ 
ваемым стеком операндов. Этот стек размещается в памяти, 
и его размер должен быть задан компилятором. В формате 
команд имеется поле, содержимое которого указывает, нахо¬ 
дится ли операнд в сегменте данных или в стеке. В последнем 
случае в формате команды поле адреса операнда отсутствует. 
Многие команды имеют различные формы представления в за¬ 
висимости от местоположения операндов-исходных данных и 
операндов-результатов, а именно: команды типа память — па¬ 
мять, память — стек, стек — стек и т. п. Если не один, а не¬ 
сколько операндов команды обращаются к стеку, то обращение 
к вершине стека выполняется в соответствии с определенным 
порядком. 

Рассмотрим еще один возможный формат команды. Пусть 
содержимое поля адреса операнда должно в результате при- 




Рис. 17.8. Варианты представления селектора объекта посредством адреса операнда. 
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вести к получению селектора объекта (т. е. селектора ВСД и 
индекса ВСД), который в соответствии со схемой, представ¬ 
ленной на рис. 17.6, должен обеспечить обращение к сегменту в 
получение значения смещения. Возможны различные способы 
решения этой задачи. 

Рис. 17.8 иллюстрирует семь возможных вариантов представ¬ 
ления селектора объекта посредством адреса операнда в коман¬ 
де. Простейший вариант предполагает использование 6-битово¬ 
го короткого прямого селектора: 2 бит для выбора ВСД, 4 бит 
для индексирования одного из первых 16 дескрипторов досту¬ 
па в ВСД. При втором варианте используется 16-битовый длин¬ 
ный прямой селектор, позволяющий индексировать один из 
16 536 дескрипторов доступа в выбранном ВСД. Третий ва¬ 
риант связан с использованием стека. (Применение стека в этом 
случае не имеет ничего общего с обращением к стеку на 
рис. 17.7; здесь стек может использоваться как для данных, 
так и для адресов.) Верхние 16 бит стека интерпретируются 
как длинный прямой селектор. 

Остальные четыре варианта предполагают получение селек¬ 
тора объекта косвенным образом и отличаются лишь размером 
некоторых полей. Поле косвенного селектора общего назначе¬ 
ния содержит селектор ВСД, индекс ВСД и смещение (послед¬ 
нее не следует путать со смещением операнда). Эта информа¬ 
ция служит для адресации (аналогично тому, как показано на 
рис. 17.6), но не операнда, а 16-битового длинного прямого се¬ 
лектора, расположенного в указанном сегменте с определенным 
смещением. Затем этот длинный прямой селектор используется 
описанным выше способом (согласно рис. 17.6) для обращения 
к сегменту, содержащему операнд. 

В соответствии с рис. 17.7, адрес данных состоит из двух 
частей: селектора объекта и смещения операнда. Возможные 
варианты представления смещения показаны на рис. 17.9. Об¬ 
щее количество этих вариантов равно 79. В сочетании с семью 
вариантами представления селектора объекта это обеспечивает 
553 различные формы представления адресов операндов в си¬ 
стеме іАРХ 432 (причем это не зависит от действительных зна¬ 
чений адресов). К полученному количеству форм представления 
адресов операндов следует еще добавить обращение к стеку 
(см. рис. 17.7). 

Возможные варианты представления смещения операнда 
можно разделить на четыре группы: скаляры, элементы записи, 
элементы вектора, элементы вектора динамического типа. Со¬ 
гласно архитектуре системы іАРХ 432, явное представление за¬ 
писей и векторов отсутствует. 

Первой и простейшей формой представления смещения яв¬ 
ляется его представление в виде скаляра: задается 7- или 16-би- 
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Рис. 17.9. Типы представления смещения операнда посредством адреса 
операнда. 


товое смещение (в байтах) в выбранном сегменте. Вторая фор¬ 
ма— это представление смещения в виде элемента записи: соз¬ 
даются два смещения, которые складываются перед использо¬ 
ванием. Первое смещение — базовая часть —команда получает 
косвенным путем, второе смещение — индексная часть — непо¬ 
средственно связано с командой в виде 7- или 16-битовой вели¬ 
чины. Следовательно, смещение в виде элемента записи обеспе¬ 
чивает адресацию к содержимому сегмента, расположенному в 
этом сегменте с некоторым переменным смещением (определяе¬ 
мым базовой частью) на фиксированном расстоянии от послед¬ 
него (определяемом индексной частью). 

Возможны семь различных способов задания переменного 
смещения — базовой части смещения. Оно может извлекаться 
в виде 16-битовой величины из вершины стека (косвенная сте¬ 
ковая адресация). Оно может считываться как 7- или 16-бито- 
вое смещение, хранимое в том же сегменте в виде операнда, 
к которому для этой цели необходимо адресоваться (косвенная 
внутрисегментная адресация). Наконец, 16-битовое базовое 
смещение может быть выбрано из заданного смещения в ука- 
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занном сегменте путем использования косвенной адресации об¬ 
щего назначения (рис. 17.9). 

Третьей формой представления смещения является его пред¬ 
ставление в виде элемента вектора. Результирующее значение 
такого смещения определяется суммированием двух компонен¬ 
тов— фиксированной базовой части смещения (которая может 
адресоваться к началу сегмента или смещению внутри сегмен¬ 
та) и переменной, или косвенной, индексной части. Последняя 
может быть задана одним из семи способов косвенной адреса¬ 
ции, подобно тому как это делается для задания базовой части 
смещения, представляемого в виде элемента записи. 

Архитектурой системы іАРХ 432 предусмотрено автоматиче¬ 
ское масштабирование индексной части смещения перед ее сум¬ 
мированием с базовой частью, т. е. машина выполняет следую¬ 
щие вычисления: 

Смещение = Базовая часть-(-(Масштабный коэффициент х 

X Индексная часть). 

Масштабный коэффициент может принимать значения 1, 2, 4, 
8 и 16. Выбор конкретного значения определяется неявно в со¬ 
ответствии с типом команды. Например, при использовании 
команды ADD-REAL масштабный коэффициент равен 8, по¬ 
скольку эта команда оперирует вещественными числами с пла¬ 
вающей точкой (8-байтовыми операндами). 

Четвертая форма представления смещения получила назва¬ 
ние «смещение в виде элемента вектора динамического типа». 
Она подобна третьей форме представления смещения и отлича¬ 
ется от нее лишь тем, что значения обеих частей смещения (ба¬ 
зовой и индексной) определяются посредством косвенной адре¬ 
сации. 

АДРЕСАЦИЯ ДЕСКРИПТОРОВ ДОСТУПА 
И ОБЪЕКТОВ 

Декодирование содержимого поля операнда команды позволя¬ 
ет установить, является ли операнд дескриптором доступа или 
объектом. После этого для непосредственного доступа к опе¬ 
ранду требуется пройти еще несколько этапов (уровней) кос¬ 
венной адресации. Более подробно этот вопрос рассматривает¬ 
ся в гл. 18. 

АДРЕСАЦИЯ С ЦЕЛЬЮ ПЕРЕДАЧИ УПРАВЛЕНИЯ 

В командах передачи управления имеется адрес особого типа, 
называемый адресом перехода и имеющий две формы представ¬ 
ления. В первом случае это 10-битовое число со знаком, нс- 
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пользуемое как смещение команды относительно начала коман¬ 
ды, содержащей адрес перехода. Во втором случае это 16-би¬ 
товое число без знака, используемое как смещение относитель¬ 
но начала сегмента, содержащего текущую команду. Смещения 
по отношению к командам в пределах сегментов команд зада¬ 
ются в битах, а не в байтах (т. е. начало и конец любой коман¬ 
ды располагаются на границах битов, а не байтов). 

ТАБЛИЦА ОБЪЕКТОВ 

Теперь целесообразно еще раз обратиться к рассмотрению таб¬ 
лицы объектов, которая используется для преобразования деск¬ 
рипторов доступа в физические адреса сегментов, и детально 
ознакомиться с ее содержимым. Таблица объектов содержит 
список 128-битовых дескрипторов. Для задания типа дескрип¬ 
тора используются два или пять младших двоичных разрядов. 
Форматы дескрипторов показаны на рис. 17.10. Рассмотрим 
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Рис. 17.10. Форматы дескрипторов в таблице объектов. (‘ — Имеет место 
обращение на промежуточной стадии реализации доступа.) 
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Таблица 17.1. Кодирование содержимого поля типа объекта/сегмента 
в дескрипторе объекта 



Базовый тип 

Значение 

Доступ 

Данные 

00000 

Сегмент доступа общего на- 

Сегмент данных общего назна- 

00001 

значения 

чения 

Зарезервировано 

Стек операндов контекста 

00010 

Домен (корневой) 

Таблица объектов 

00011 

Зарезервировано 

Сегмент «команды» 

00100 

Контекст (корневой) 

Сегмент данных контекста 

00101 

Процесс (корневой) 

Сегмент данных процесса 

00110 

Процессор GDP (корневой) 

Сегмент данных процессора 

00111 

Порт (корневой) 

Сегмент данных порта 

01000 

Транспортер (корневой) 

Сегмент данных транспортера 

01001 

Ресурсы памяти (корневые) 

Сегмент данных ресурсов па¬ 
мяти 

01010 

Определение типа 

Сегмент данных связи 

01011 

Зарезервировано 

Сегмент данных управления 
дескриптором 

01100 

* 

Сегмент данных управления 
аффинажем 

01101 

Зарезервировано 

Зарезервировано 

01110 



01111 

» 

» 


дескрипторы объекта (памяти) и заголовка таблицы объектов» 
а также так называемый свободный дескриптор. Основной ин¬ 
формацией дескриптора объекта или памяти являются 24-би¬ 
товый физический адрес базы (начала) сегмента, 16-битовая 
длина сегмента (в байтах) и его тип. Информация о типе сег¬ 
мента размещается в двух полях: 1-битовом поле «базовый 
тип» (0 — сегмент данных, 1 — сегмент доступа) и 5-битовом 
поле «тип объекта/сегмента» (возможное содержимое этого по¬ 
ля дано в табл. 17.1). Бит готовности указывает, можно ли ис¬ 
пользовать данный дескриптор объекта для обращения к сег¬ 
менту. Бит — указатель наличия соответствующей памяти, буду¬ 
чи равным 0, вызовет регистрацию ошибки, если при этом пред¬ 
принимается попытка адресации посредством дескриптора объ¬ 
екта. Этот бит может использоваться программными средства¬ 
ми системы для индикации отсутствия текущего сегмента в па¬ 
мяти. Бит изменения обычно имеет значение 0, которое ему 
присваивается перед началом работы. Процессор присваивает 
этому биту значение 1 при любых изменениях запоминающей 
среды (памяти) в сегменте. Бит доступа также обычно имеет 
значение 0, устанавливаемое программными средствами перед 
началом работы или периодически. Процессор присваивает это¬ 
му биту значение 1 в том случае, когда реализован доступ к 
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запоминающей среде этого сегмента. Перечисленные биты (по¬ 
ля формата дескриптора) предназначены для организации пе¬ 
ремещения сегментов между различными уровнями иерархии 
адресного пространства памяти системы, т. е. для постранич¬ 
ного обмена средствами операционной системы. 

Номер уровня 16 бит указывает на «продолжительность 
жизни» сегмента. Если его значение равно 0, это подразумева¬ 
ет, что сегмент был выделен из общего пула («кучи») памяти 1 ). 
Если значение номера уровня отлично от нуля, это указывает 
на факт создания сегмента в процессе обращения к подпро¬ 
грамме, причем это значение является номером динамически 
устанавливаемого уровня вложения активации подпрограммы. 
Эта информация совместно с флагом повторного запроса (па¬ 
мяти, занимаемой объектами) используется для процедуры 
«сбора мусора». Бит — указатель «сегмент не очищен» равен 1, 
если сегмент содержит биты, не равные 0. Поскольку все вы¬ 
деляемые для работы сегменты «очищены», пространство памя¬ 
ти, выделяемое из «неочищенного» сегмента заполняется дво¬ 
ичными нулями. 

Все поля формата дескриптора объекта, помеченные как за¬ 
резервированные, аппаратными средствами системы не исполь¬ 
зуются и предоставляются в распоряжение программных средств 
(например, операционной системе). Поля, помеченные как ре¬ 
зервируемые, . либо не используются, но могут быть использо¬ 
ваны при расширении системы в будущем, либо используются 
аппаратными средствами для целей, не предусмотренных в оп¬ 
ределении архитектуры системы. 

Теперь рассмотрим свободный дескриптор. Он просто описы¬ 
вает незанятую позицию в таблице объектов. Зарезервирован¬ 
ные области могут использоваться программными средствами 
для соединения всех свободных дескрипторов вместе. 

Дескриптор, именуемый «заголовок таблицы объектов», 
включает в себя некоторую общую информацию о таблице объ¬ 
ектов. Поле свободного индекса содержит ссылку на первый 
дескриптор в таблице объектов, поле индекса конца — ссылку 
на последний дескриптор этой таблицы. В 32-битовом поле за¬ 
проса памяти указывается общее количество памяти, которая 
может быть выделена для сегментов, связанных с данной таб¬ 
лицей объектов. Если во всех разрядах этого поля содержат¬ 
ся 1, то ограничения на запрашиваемую память отсутствуют. 
В противном случае указанные ограничения претерпевают из¬ 
менения («подстраиваются») при каждом выделении памяти 
для сегментов или освобождении ранее выделенной памяти. 


11 Слово «куча» по-английски heap; отсюда происхождение термина 
-схип-флаг» (heap flag) . — Прим. ред. 
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Если таблицу объектов ассоциировать с некоторым процессом, 
то упомянутый запрос памяти в системе іАРХ 432 можно счи¬ 
тать подобным понятию AM (имеющейся в наличии памяти) в 
системе SWARD. 

ЗАЩИТА ОТ НЕСАНКЦИОНИРОВАННОГО 
ДОСТУПА 

Как отмечалось выше, предотвращение несанкционированного 
доступа в системе іАРХ 432 основано на использовании защи¬ 
щенных потенциальных адресов, снабженных правами объек¬ 
та (на чтение содержимого сегмента или записи информации в 
сегмент) и правами системы (на выполнение команд, опери¬ 
рующих сегментом как системным объектом). Защита потен¬ 
циальных адресов осуществляется путем их записи в сегмент 
особого типа (сегмент доступа). В дополнение к этому система 
іАРХ 432 располагает некоторыми средствами, по своим функ¬ 
циям родственными средствам защиты потенциальных адресов. 

ОБЪЕКТ сУПРАВЛЕНИЕ ДЕСКРИПТОРОМ» 

Подобно системе SWARD, система іАРХ 432 не содержит при¬ 
вилегированных команд. Однако в отличие от системы SWARD 
никаким программам рассматриваемой здесь системы не раз¬ 
решается выполнять какую-либо команду односторонне. Неко¬ 
торые команды требуют возможности обращения к объекту 
«управление дескриптором» (ОУД) как к операнду. В этом 
объекте указывается, что разрешается делать соответствующей 
команде. 

Такой объект является 32-битовым сегментом данных. К не¬ 
му могут обращаться следующие три команды: CREATE- 
TYPED-SEGMENT, RESTRICT-RIGHTS и AMPLIFY-RIGHTS. 
В ОУД имеются соответствующие поля. Во-первых, это 1-бито¬ 
вое поле «базовый тип» и 5-битовое поле «тип объекта/сегмен¬ 
та» (см. табл. 17.1); содержимое этих полей определяет тип 
сегмента, который может быть создан любым «владельцем» 
средств адресации к данному ОУД. Во-вторых, в ОУД имеются 
поля прав объекта и прав системы, определяемые согласно опи¬ 
санию дескриптора доступа. В дополнение к этому дескриптор 
доступа к ОУД, как к объекту, имеет права системы. Послед¬ 
ние представляют собой возможность использовать ОУД, во- 
первых, для создания системного объекта (т. е. любого объ¬ 
екта, кроме сегментов данных или общего доступа) и, во-вто¬ 
рых, для расширения прав в дескрипторе доступа. 

Для создания сегмента системного типа (например, домена, 
корневого сегмента доступа процесса, сегмента данных процес- 
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са) используются команда CREATE-TYPED-SEGMENT, непо¬ 
средственно формирующая сегмент, а затем команды манипу¬ 
ляции данными для инициализации этого сегмента. Чтобы 
предотвратить произвольное создание объектов какой-либо» 
программой, команда CREATE-TYPED-SEGMENT должна 
иметь возможность обращаться к ОУД как к операнду, а ее 
дескриптор доступа должен иметь права системы на создание» 
системного объекта. После этого на основании информации в> 
ОУД определяется тип сегмента. 


ОГРАНИЧЕНИЕ И РАСШИРЕНИЕ ПРАВ ДОСТУПА 
В ПОТЕНЦИАЛЬНЫХ АДРЕСАХ 

В отличие от системы SWARD в системе іАРХ 432 имеется воз¬ 
можность расширения прав доступа в потенциальных адресах.. 
Очевидно, что при этом необходимо принять соответствующие- 
меры по защите от несанкционированных действий. Для этою 
цели используется ОУД. Для объекта определенного типа со¬ 
ответствующий ОУД обычно находится под сильным контро¬ 
лем спецификатора типа этого объекта и используется для по¬ 
лучения особых привилегий для этого объекта. 

Команда AMPLiFY-RIGHTS, предназначенная для расши¬ 
рения упомянутых прав, позволяет обращаться к дескриптору 
доступа и ОУД. Дескриптор доступа к ОУД должен содержать, 
права системы, что формулируется следующим образом: «мо¬ 
жет быть использован для расширения прав». ОУД содержит; 
флаги прав объекта и системы, результаты выполнения логи¬ 
ческих операций ИЛИ над которыми записываются в соответст¬ 
вующие поля адресуемого дескриптора доступа. 

Команда RESTRICT-RIGHTS, предназначенная для ограни¬ 
чения рассматриваемых прав доступа, позволяет обращаться к. 
дескриптору доступа и ОУД или 32-битовой области, похожей; 
на ОУД (называемой «забытой ОУД»). Содержащаяся в ОУД 
информация о правах объекта и системы подвергается логиче¬ 
ской операции И с записью результата в соответствующие полю 
адресуемого дескриптора доступа с целью ограничения его прав 
доступа и сохранения их неизменными. Наличие «забытого» 
ОУД» позволяет любой программе односторонне ограничивать, 
права доступа в любом из ее дескрипторов доступа. 

Система іАРХ 432 предоставляет возможность использова¬ 
ния (по усмотрению программиста) одной дополнительной опе¬ 
рации контроля процесса модификации прав доступа. По жела¬ 
нию пользователя можно присвоить значение 1 биту «Проверка? 
типа» в ОУД. Тогда при любом использовании ОУД для изме¬ 
нения прав доступа система прежде всего проверяет, соответ¬ 
ствует ли тип сегмента, к которому производит обращение под- 
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лежащий модификации дескриптор доступа, тому типу, который 
задан в ОУД (например, в распоряжении может быть ОУД, 
допускающий расширение прав только в тех дескрипторах до¬ 
ступа, которые адресуются к портам связи). 

Возможность расширения прав доступа оказывается наибо¬ 
лее эффективным средством в сочетании с возможностями спе¬ 
цификатора типа объекта. Рассмотрим, например, такой спе¬ 
цификатор как часть операционной системы, в ведении которой 
находятся порты связи. Одной из функций такого специфика¬ 
тора могло бы быть «создание порта», другой — «определение 
размера очереди запросов к порту». Реализация первой функ¬ 
ции вероятнее всего сводилась бы к выдаче дескриптора досту¬ 
па с правами системы на прием и передачу через порт, однако 
без прав объекта на анализ или модификацию сегментов порта. 
Выполнение операций над дескриптором доступа по реализации 
второй функции приводило бы к временному расширению прав 
доступа дескриптора на анализ состояния порта. 

ОБЪЕКТЫ УПРАВЛЕНИЯ АФФИНАЖЕМ 

Формирование аффинажа — процесс фрагментации сегмента — 
можно рассматривать, согласно изложенному в предыдущем 
разделе, как действия по созданию нового объекта или сегмен¬ 
та из смежных областей памяти существующего сегмента. Если 
для такого нового сегмента хотят сохранить те же самые ба¬ 
зовый и системный типы, что и у существующего сегмента, то 
не требуется запроса никаких специальных привилегий; доста¬ 
точно воспользоваться командой CREATE-GENERIC- 
REFINEMENT. По этой команде формируется дескриптор до¬ 
ступа, адресующийся не к дескриптору объекта, а к дескрипто¬ 
ру аффинажа в таблице объектов (рис. 17.10). Последний ис¬ 
пользуется для получения дескрипторов доступа к особым пе¬ 
ременным программы, представляющим фактические параметры 
для подпрограммы. 

В отдельных случаях может возникать необходимость в со¬ 
здании сегмента доступа с последующим выделением из него 
других сегментов; некоторые из них должны быть даже кор¬ 
невыми сегментами для системных объектов различного ти¬ 
па. Например, в таком случае при программировании на языке 
Ада задача могла бы быть представлена как объект «домен» 
(сегмент доступа), объект «процесс» (один сегмент доступа, 
один сегмент данных), один или несколько портов связи (один 
сегмент доступа, один сегмент данных) для каждого входа в 
задачу и один или несколько сегментов «команды» (сегмен¬ 
ты данных). Вместо того чтобы для каждого подобного объекта 
создавать свои сегменты, появляется возможность сформировать 
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единственный сегмент доступа, пользуясь которым можно вы¬ 
делять сегменты доступа для различных объектов. Это могло 
бы привести к более эффективному управлению памятью. Так,, 
при «перекачивании» сегментов из основной памяти на диски и 
обратно можно было бы избавиться от манипулирования боль¬ 
шим количеством сегментов малых размеров; взаимосвязанные- 
сегменты оказываются физически сгруппированными вместе, по¬ 
добно группе доступа в архитектуре Системы 38 фирмы IBM., 

Для получения описанных возможностей необходимо наличие 
специальных привилегий, заключенных в объекте «управление 
аффинажем». Используемая для этих целей команда CREATE- 
TYPED-REFINEMENT обусловливает обращение с этим объек¬ 
том как с операндом. Информация, заключенная в 32-битовом 
сегменте данных объекта «управления аффинажем», указывает 
системный тип объекта, который может быть создан как аф¬ 
финаж. 

Кроме перечисленных выше возможностей время от време¬ 
ни может потребоваться функция, состоящая в следующем: по¬ 
средством заданного дескриптора доступа к аффинажу создать 
дескриптор доступа к сегменту, охватывающему (содержащему) 
данный аффинаж. Такая операция должна быть защищена от 
несанкционированного доступа, поскольку в противном случае 
возможно нарушение принципа защиты с помощью доменов. Вы¬ 
полняющая эту функцию команда RETRIEVE-REFINED- 
OBJECT предписывает использование объекта «управление- 
аффинажем» в качестве операнда. 

Другие вопросы, связанные с проблемой защиты от несанк¬ 
ционированного доступа, рассматриваются в разделе, содержа¬ 
щем описание объектов, определяемых программными сред¬ 
ствами. 


СТРУКТУРА ПРОГРАММЫ 

Для описания структуры программ системы іАРХ 432 исполь¬ 
зуются объекты «домен», «команды» и «контекст». Объекты 
первых двух типов позволяют описывать статическую структуру 
программы, объекты третьего типа — динамическую, так как 
создаются машиной в результате вызова подпрограмм. 

Объект «команды» содержит последовательность машинных 
команд, относящихся обычно к одной подпрограмме. Посколь¬ 
ку для адресации к командам используется смещение, выра¬ 
жаемое в битах, размер объектов «команды» не превышает 
8192 байт. Подпрограммы, размер которых превышает указан¬ 
ный предел для объектов «команды», могут быть представлены 
посредством группы таких объектов. 
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Каждый объект «команды» — это один сегмент данных, со¬ 
держащий семь 2-байтовых полей, за которым следуют коман¬ 
ды. Эти поля содержат следующую информацию: 1) длину сег¬ 
мента доступа контекста (эта величина используется машиной 
х целью выделения корневого сегмента доступа для объекта 
«контекст» при вызове объекта «команды»); 2) длину сегмента 
данных контекста; 3) длину стека операндов контекста; 4) сме¬ 
щение первой команды, подлежащей выполнению; 5) индекс 
.ДД к сегменту данных — констант в объекте «домен»; 6) индекс 
_ДД к сегменту ошибок объекта в объекте «домен» (команды 
этого сегмента подлежат выполнению при обнаружении ошибки 
в контексте); 7) индекс ДД к сегменту трассировки объекта в 
-в объекте «домен» (команды этого сегмента подлежат выпол¬ 
нению, когда осуществляется выполнение трассируемой коман¬ 
ды). 

В ДД к сегменту команд указываются следующие систем¬ 
ные права: 1) можно ли вызывать сегмент команд; 2) можно 
ли выполнять трассировку процесса выполнения команд сег- 
-мента. 

Объект «домен» служит для группировки набора объектов 
«команды» и сегментов данных. Понятию «домен» системы 
іАРХ 432 соответствует понятие «пакет» в программе на языке 
Ада. При выполнении своих функций домен адресуется к объ¬ 
ектам «команды», которым в языке Ада соответствуют подпро¬ 
граммы и другие конструкции из операторов описания, входя¬ 
щие в состав пакета, а также обращается к сегментам данных, 
описывающим статические переменные общего и частного до¬ 
ступа, а также константы, генерируемые компилятором. 

Объект «домен» — это одиночный сегмент доступа. В отли¬ 
тие от большинства объектов других типов он не имеет фикси¬ 
рованного формата. Порядок следования в нем дескрипторов 
.доступа к объектам «команды», сегментам данных и другим 
адресуемым элементам определяется программными средства¬ 
ми, например компилятором. Путем создания аффинажа доме¬ 
на некоторые из связанных с ним объектов (подмножество сег¬ 
ментов команд и данных) можно сделать объектами общего до¬ 
ступа (т. е. адресуемыми из других доменов), а другие сохра¬ 
нять как объекты частного доступа (т. е. адресуемые только из 
тех объектов «команды», которые взаимосвязаны с данным до¬ 
меном). Архитектурой системы іАРХ 432 не предусмотрено оп¬ 
ределение конкретного значения системных прав в дескрипторе 
.доступа. 

Объект «контекст» играет ключевую роль в системе іАРХ 432, 
•поскольку определяет динамическое состояние «окружения» 
программы во время ее выполнения. Это единственный объект, 
•создаваемый машиной неявным образом. Выполнение програм- 
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мы представлено в системе списком контекстов — одним для 
каждой активной подпрограммы. При этом последним в списке 
является контекст, описывающий динамику всех средств систе¬ 
мы, «окружающих» процесс во время его протекания. 

При обращении к сегменту команд машина создает два сег¬ 
мента: корневой сегмент доступа и один сегмент данных 
(рис. 17.11). Информация из предыдущего контекста и вызван¬ 
ного сегмента команд используется для инициализации новых 
сегментов контекстов. Если сегмент команд был вызван коман¬ 
дой CALL-CONTEXT-WITH-MESSAGE (а не просто командой 
CALL), дескриптор доступа сообщения (обычно сегмент досту¬ 
па, адресующийся к параметрам) вставляется в новый сегмент 
доступа. Следует помнить, что сам сегмент доступа контекста 
адресуется селектором 0 входного сегмента доступа. Он так¬ 
же содержит дескрипторы доступа к ВСД, выбираемым селекто¬ 
рами 1, 2 и 3. 

Сегмент данных контекста описывает текущее состояние 
контекста. Так называемое поле состояния сегмента позволяет 
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управлять точностью и процедурой округления операций с пла¬ 
вающей точкой в контексте. Содержимое этого поля может мо¬ 
дифицироваться посредством команды SET-CONTEXT-MODE. 
Указатель стека определяет положение вершины стека операн¬ 
дов в каждый данный момент. Индекс объекта «команды» ука¬ 
зывает местоположение индекса дескриптора доступа сегмента 
текущих команд в пределах соответствующего домена. Указа¬ 
тель команды определяет положение текущей машинной коман¬ 
ды. Во время выполнения процессором контекста предсказать 
содержимое большинства перечисленных полей невозможно. 

Другая, следующая за описанными полями часть сегмента 
данных контекста используется компилятором в качестве памя¬ 
ти для локальных переменных подпрограммы. И наконец, часть 
этого сегмента, имеющая адреса с наибольшими значениями, 
служит стеком операндов. 

Согласно изложенному в разделе об адресации, в качестве 
данных, адресуемых операндами команды, может использо¬ 
ваться только содержимое стека операндов и сегмента, дескрип¬ 
тор доступа которого находится либо в корневом сегменте до¬ 
ступа контекста (поскольку этот сегмент является ВСД 0), 
либо в сегменте доступа, адресуемом дескрипторами доступа к 
ВСД 1, ВСД 2 или ВСД 3 в корневом сегменте контекста. Не 
исключается возможность для компилятора использовать ВСД 
0 в качестве средства доступа к локальным переменным (в сег¬ 
менте данных контекста) и константам (которые могут быть 
помещены в сегмент данных, связанный с данным объектом «до¬ 
мен») . Объект, посылаемый этому контексту как сообщение, мо¬ 
жет иметь его дескриптор доступа, скопированный в поле 
ВСД 1, что дает командам возможность доступа к парамет¬ 
рам путем выбора ВСД 1 в адресах операндов. ВСД 2 можно 
использовать для обращения либо к сегменту доступа, адре¬ 
сующемуся к статическим переменным, связанным с данным 
доменом, либо к глобальным переменным (переменным общего 
доступа), связанным с процессом. 

Если программа выполняет обработку списка какого-либо 
типа, компилятор может резервировать ВСД 3 для этой цели. 
Например, если сегмент А производит обращение к сегменту В, 
который в свою очередь производит обращение к сегменту С, 
работу можно начать, располагая дескриптором доступа к А в 
предназначенном для ВСД 3 элементе сегмента доступа кон¬ 
текста. Для получения возможности адресации к дескрипторам 
доступа сегмента В необходимо дескриптор доступа к В поме¬ 
стить в элемент, предназначенный для ВСД. Это можно сделать 
путем выполнения команды ENTER-ACCESS-SEGMENT, зада¬ 
вая в качестве операндов величину 3 для ВСД 3 и значение 
дескриптора доступа в А к В. 
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ПРОЦЕССОРЫ И ПРОЦЕССЫ 

Архитектуре системы іАРХ 432 присущи хорошая организация 
одновременно протекающих процессов и высокая степень согла¬ 
сования совместной работы группы процессоров. Прежде всего 
заслуживают внимания средства синхронизации и связи как 
между процессорами, так и между процессами, а также сред¬ 
ства, дающие возможность программному обеспечению (напри¬ 
мер, операционной системе) принимать участие в планировании 
протекания процессов. 

ОБЪЕКТ «ПРОЦЕССОР» 

Объект «процессор» используется при описании архитектуры си¬ 
стемы для представления реального процессора. (В дальнейшем, 
однако, рассмотрению подлежит только процессор общего на¬ 
значения.) Обычно объект «процессор» может находиться в од¬ 
ном из следующих двух состоянийг 1) имеется связанный с ним 
объект «процесс», т. е. процессор выполняет команды согласно 
некоторому контексту в этом процессе; 2) процессор находится 
в очереди на обслуживание некоторым портом диспетчериза¬ 
ции, т. е. процессор ожидает получения работы. На рис. 17.12 
дано схематическое изображение объекта «процессор». Он пред¬ 
ставляет собой некоторую структуру данных, состоящую из 
корневого сегмента доступа, двух сегментов данных и объекта 
«транспортер» (состоящего из сегмента доступа и сегмента 
данных). (Сегментом данных глобальных связей обычно поль¬ 
зуются все процессоры.) Сегменты данных для локальных и 
глобальных связей используются для обмена сообщениями меж¬ 
ду процессорами; ниже более подробно будет описано назначе¬ 
ние этих сегментов. 

Сегмент доступа процессора содержит два важных средства 
адресации: дескриптор доступа к справочнику таблиц объектов 
и дескриптор доступа к нормальному порту. Первый дескриптор 
обеспечивает процессору доступ к справочнику таблиц объек¬ 
тов с целью разрешения адресных ссылок, второй адресует его 
к порту диспетчеризации, из которого процессор получает про¬ 
цессы. Большая часть прочей информации сегмента доступа про¬ 
цессора используется в случае возникновения аномальных си¬ 
туаций. Аварийный порт — это специальный порт диспетчери¬ 
зации, к которому процессор подключается при обнаружении в 
машине не поддающейся восстановлению потери питания. Порт 
диагностики — еще один специальный порт диспетчеризации, 
к которому подсоединяется процессор при обнаружении в вы¬ 
полняемой программе ошибок некоторого типа. Порт реконфи¬ 
гурации системы используется для подключения к нему процес» 
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Рис. 17.12. Представление объекта «процессор». 
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сора в тех случаях, когда возникают особые ситуации в работе 
памяти совместно с общей шиной, связанные с решением задач 
возможного будущего расширения конфигурации аппаратных 
средств системы. 

Сегмент данных процессора содержит информацию о состоя¬ 
нии процессора и некоторых ошибках (см. раздел по обработ¬ 
ке ошибок). Информация включает следующие сведения: 1) те¬ 
кущее состояние процессора (бездействие, начальная установ¬ 
ка, выполнение или выбор процесса); 2) режим диспетчериза¬ 
ции (нормальный, аварийный, диагностический или реконфигу¬ 
рации); 3) установлен ли данный процессор другим процессо¬ 
ром в состояние «Останов»; 4) приняты ли сообщения, переда¬ 
ваемые другими процессорами; 5) значение 8-битового иден¬ 
тификатора процессора. Во время выполнения процесса регист¬ 
рации точного состояния процессора в соответствующем поле 
его сегмента данных не производится. Информацию об истин¬ 
ном состоянии процессора и интервале времени его работы 
можно получить в программе с помощью команды READ- 

PROCESSOR-STATUS-AND-CLOCK. 

ОБЪЕКТ «ПРОЦЕСС» 

На рис. 17.13 изображен объект «процесс». Он состоит из кор¬ 
невого сегмента доступа, сегмента данных, определяемого про¬ 
граммными средствами сегмента доступа, а также сегмента до¬ 
ступа и связанного с ним сегмента данных, объединенных под 
общим названием «транспортер» и описываемых в разделе, по¬ 
священном коммуникациям между процессами. Отметим, что 
процесс адресуется к таблице объектов. Как уже указывалось, 
весьма вероятно, что созданный программными средствами про¬ 
цесс будет располагать своей собственной таблицей объектов, 
на основании которой можно создавать дескрипторы объектов, 
подобно тому как процесс создает сегменты. 

Процесс адресуется и к порту диспетчеризации. Поместить 
процесс в порт диспетчеризации — это функция аппаратных, 
а не программных средств машины. Например, если процессор 
принимает решение приостановить выполнение своего собствен¬ 
ного процесса и выбрать из своего порта диспетчеризации дру¬ 
гой процесс, то такому процессору необходимо поместить теку¬ 
щий процесс в очередь на обслуживание портом диспетчериза¬ 
ции. Порт планирования — это порт связи, которому процессор 
посылает процесс после того, как последний находился на об¬ 
служивании в порту диспетчеризации заданное число раз. Порт 
ошибки — это порт связи, в очередь на обслуживание которым 
помещается процесс в случае обнаружения ошибок в самом 
процессе. 
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Рис. 17.13. Представление объекта «процесс». 


Сегмент данных процесса содержит информацию, необходи¬ 
мую для управления памятью и обработки ошибок, а также так 
называемую управляющую информацию, формат представления 
которой показан на рис. 17.14. Период обслуживания и число 
периодов обслуживания — это параметры планирования обслу¬ 
живания процессов процессорами. Посредством этих парамет¬ 
ров программные средства системы (например, операционная 
система) могут оказывать влияние на диспетчеризацию процес¬ 
сов процессорами. Период обслуживания — это интервал време¬ 
ни (интервал выполнения), при превышении которого процес- 
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сор вынужден поместить процесс обратно 
в порт диспетчеризации и попытаться выб¬ 
рать другой процесс. Число периодов об¬ 
служивания указывает количество перио¬ 
дов обслуживания, предоставленных про¬ 
цессу; при попытке запроса большего чис¬ 
ла периодов обслуживания процессор по¬ 
сылает процесс в порт диспетчеризации. 

Находящаяся в сегменте данных про¬ 
цесса информация о состоянии процесса 
содержит следующие данные: 1) связан ли 
в настоящее время процесс с каким-либо 
процессором (т. е. выполняется ли про¬ 
цесс); 2) обнаружена ли ошибка в процес¬ 
се; 3) ожидает ли процесс сообщения, на¬ 
ходясь у некоторого порта; 4) подлежат ли 
ошибки процесса обработке как таковые 
или как ошибки контекста; 5) какой ре¬ 
жим трассировки задан (никакой, трасси¬ 
ровка ошибок, трассировка передачи уп- 
правления, полная трассировка). Информа¬ 
ция о продолжительности процесса пред¬ 
ставлена 32-битовой величиной, указываю¬ 
щей (в единицах времени, соответствую¬ 
щих длительности периода внешнего такто¬ 
вого генератора) время, которое уже из¬ 
расходовано на обслуживание данного процесса. Номера уров¬ 
ней ВСД — это номера уровней контекстов, в которых были 
созданы входные сегменты доступа текущего контекста. 

Ш рис. 17.13 показан еще один сегмент доступа, связан¬ 
ный с сегментом доступа процесса. Его функциональное назна¬ 
чение в системе не является раз навсегда определенным; пред¬ 
полагается, что он может быть использован для определения 
местоположения глобальных объектов или переменных процес¬ 
са. Поскольку обычно процесс не имеет дескриптора доступа к 
самому себе, в системе предусмотрена специальная команда 
ENTER-GLOBAL-ACCESS-SEGMENT, позволяющая иметь дес¬ 
криптор доступа к этому сегменту, который вставляется в одно 
из полей для ВСД в контексте. 
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Рис. 17.14. Формат 
представления 
информации об 
управлении 
процессом в сегменте 
данных процесса. 


ПЛАНИРОВАНИЕ И ДИСПЕТЧЕРИЗАЦИЯ 
ПРОЦЕССОВ 

Система іАРХ 432 располагает чрезвычайно гибкими средства¬ 
ми программного управления планированием и диспетчериза¬ 
цией процессов. В дальнейших рассуждениях не будем прово- 
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Рис. 17.15. Три возможных варианта диспетчеризации. 


дить различий между этими средствами и операционной систе¬ 
мой, поскольку операционной системе не присущи особые права, 
функции и привилегии, т. е. и некоторая прикладная программа 
может, например, создавать процессы и управлять ими само¬ 
стоятельно, получив необходимые исходные данные, такие, как 
объект «управление дескриптором», позволяющий создавать 
объекты «процесс». Упомянутая гибкость средств достигается 
благодаря 1) развитой системе взаимосвязей между портами 
диспетчеризации и процессорами, 2) присваиванию портам дис¬ 
петчеризации определенных правил организации очередей, 
3) присваиванию процессам параметров плана их обслужива¬ 
ния, 4) наличию порта планирования и 5) наличию порта за¬ 
держки. 

Развитая система взаимосвязей между портами диспетчери¬ 
зации и процессорами позволяет с использованием средств опе¬ 
рационной системы создавать многочисленные конфигурации 
схем диспетчеризации процессов. На рис. 17.15 показаны три 
такие схемы. В схеме на рис. 17.15, а все процессоры пользу¬ 
ются общим пулом работ (процессов) в единственном порте дис¬ 
петчеризации. Следовательно, в этом случае операционная си¬ 
стема не вовлечена в распределение процессов между процес¬ 
сорами. Схема, показанная на рис. 17.15,6, является противопо¬ 
ложным случаем. Здесь у каждого процессора свой порт диспет- 
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черизации, и операционной системе приходится принимать ре¬ 
шение, между какими процессами и процессорами устанавли¬ 
вать связи при создании процессов. Схема на рис. 17.15, в за¬ 
нимает некоторое промежуточное положение между двумя рас¬ 
смотренными экстремальными случаями: пул процессоров свя¬ 
зан с одним портом диспетчеризации, а другой подобный порт 
предоставлен некоторому процессору (например, для обслужи¬ 
вания какого-либо процесса с экстраординарными характери¬ 
стиками). 

Порт диспетчеризации — это объект, представляющий оче¬ 
редь процессов или процессоров (но не одновременно и тех и 
других). Формат описания такого порта показан на рис. 17.2. 
Хотя управление порядком обслуживания очередей в порте дис¬ 
петчеризации может быть предоставлено операционной системе, 
столь высокий уровень управления программными средствами 
обычно не допускается, поскольку зачастую он может оказать¬ 
ся неэффективным. Вместо этого операционную систему можно 
использовать для определения системы правил организации оче¬ 
редей для каждого порта диспетчеризации и для задания пара¬ 
метров для каждого процесса. Следовательно, в системе 
іАРХ 432 принята следующая стратегия планирования обслужи¬ 
вания процессов: аппаратные средства ответственны за плани¬ 
рование на низком уровне, операционная система — на высо¬ 
ком. 

Поле состояния порта диспетчеризации содержит информа¬ 
цию о том, какое правило организации очередей задано для дан¬ 
ного порта: «поступивший первым — обрабатывается первым» 
(FIFO) или «приоритет и гарантированные сроки обслужива¬ 
ния (ГСО)». Эта информация используется процессором всякий 
раз, когда необходимо поместить процесс в очередь на обслужи¬ 
вание портом диспетчеризации (например, по истечении периода 
времени обслуживания процесса процессором). Если очередь 
организована по принципу FIFO, то процесс просто помещается 
в ее конец. При организации очереди с учетом приоритетов про¬ 
цессы располагаются в соответствии со значениями приорите¬ 
тов. Процессы с равными значениями приоритетов обслужива¬ 
ются согласно правилу ГСО. Каждому процессу предоставля¬ 
ется право указать время относительной задержки, т. е. макси¬ 
мальный интервал времени, в течение которого процесс может 
ожидать обслуживания, находясь в очереди. Перед помещением 
процесса в очередь процессор добавляет указанное время за¬ 
держки к интервалу времени обслуживания процессором про¬ 
цесса. В результате получается так называемое предельное вре¬ 
мя запуска. (Часы отдельных процессоров синхронизированы 
между собой.) В соответствии со значением предельного време¬ 
ни запуска процессор помещает процесс в ту или иную пози- 
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цию очереди, организованной согласно порядку следования 
значений этих времен. 

Отметим, что некоторая дополнительная информация, та¬ 
кая, как приоритет процессов, поступает из объекта «транс¬ 
портер», показанного на рис. 17.13. Эти объекты используются 
прежде всего для формирования очередей; они «транспортиру¬ 
ют» некоторый объект в очередь. Выше отмечалось, что у пор¬ 
тов имеется некоторое, фиксированное программными средст¬ 
вами пространство для размещения элементов очередей. Ис¬ 
пользование транспортеров дает возможность неограниченно 
расширять это пространство, формируя очередь в виде списка 
взаимосвязанных транспортеров. Объект «транспортер» созда¬ 
ется для каждого объекта «процесс» и объекта «процессор», 
а также и для других целей (описываемых в последующих раз¬ 
делах) . 

В дополнение к упомянутым параметрам приоритета и за¬ 
держки каждому процессу назначается период обслуживания 
(максимальный интервал времени выполнения процесса, по 
истечении которого процессор пытается переключиться на об¬ 
служивание другого процесса) и число периодов обслуживания 
(максимально допустимое число периодов обслуживания про¬ 
цесса процессором). При превышении значения последнего про¬ 
цессор выполняет неявно заданную команду SEND с целью пе¬ 
редачи данного объекта «процесс» как сообщения заранее ука¬ 
занному порту планирования. Операционная система получает 
возможность принимать сообщения из этого порта. Она фор¬ 
мирует решение о завершении процесса или перепланировке его 
обслуживания портом диспетчеризации, возможно, с изменен¬ 
ными параметрами планирования обслуживания. 

Процесс может оказывать влияние на планирование своего 
собственного обслуживания путем выполнения команды 
DELAY. Эта команда позволяет задать минимальный интервал 
времени, на который желательно приостановить выполнение 
процесса, прежде чем продолжить его дальнейшее выполнение. 
Следствием реализации команды DELAY является выполнение 
неявно заданной команды SEND, направляющей процесс 
на обслуживание в порт задержки, который относится к 
классу портов, отличному от ранее рассмотренных. Оче¬ 
редь «задерживаемых» процессов в порте задержки ре¬ 
гулируется, согласно правилам ГСО, на основе желательных 
для процессов интервалов задержки их выполнения. В процес¬ 
соре аппаратным путем реализован алгоритм, обеспечивающий 
периодическую инспекцию порта задержки, соответствующего 
данному процессору. Так, если процессор бездействует, ожидая 
поступления запроса на обслуживание у порта диспетчериза¬ 
ции, то, благодаря указанному алгоритму, он периодически «про- 
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буждает» себя и опрашивает порт задержки. По истечении ин¬ 
тервала задержки, устанавливаемого упомянутыми правилами 
задержки выполнения процессов, процессор помещает процесс в 
очередь своего порта диспетчеризации. 


ОБМЕН СООБЩЕНИЯМИ МЕЖДУ ПРОЦЕССОРАМИ 


Архитектурой системы іАРХ 432 предусмотрена для физически 
реализованных процессоров возможность взаимосвязи путем 
обмена сообщениями (эту возможность не следует путать с ком¬ 
муникациями между процессами). Межпроцессорные связи 
иногда выполняются неявно (в результате происшествия в си¬ 
стеме определенных событий, не поддающихся управлению про¬ 
граммными средствами), а иногда этими связями управляют 
явным образом с помощью команд SEND-TO-PROCESSOR и 
BROADCAST-TO-PROCESSOR. 

При реализации межпроцессорных связей необходимо ис¬ 
пользование сегментов данных локальных и глобальных связей, 
показанных на рис. 17.12. Имеются две формы представления 
межпроцессорных сообщений: одна—для передачи сообщений 
только специально указанным процессорам, другая — для пере¬ 
дачи всем процессорам, которые совместно используют сегмент 
данных глобальных связей. Различают сообщения следующих 
типов: 


Пуск процессора 
Задать режим приема гло¬ 
бальных сообщений 
Войти в режим «тревога» 
Войти в нормальный режим 

Сделать недействительной ин¬ 
формацию в кэш-памяти сег¬ 
мента данных 

Приостановить выполнение и 
установить информацию кон¬ 
текста 

Приостановить работу и уста¬ 
новить информацию процес¬ 
сора 

Побудка бездействующего 
процессора 


Останов процессора 
Отменить режим приема гло¬ 
бальных сообщений 
Войти в режим диагностики 
Войти в режим реконфигура¬ 
ции 

Сделать недействительной ин¬ 
формацию в кэш-памяти таб¬ 
лицы объектов 

Приостановить выполнение и 
установить заново информа¬ 
цию процесса 

Приостановить работу и уста¬ 
новить заново всю информа¬ 
цию процессора 


Дадим краткие пояснения перечисленным директивам. На¬ 
значение пуска и останова процессора очевидно. Сообщение о 
задании режима приема глобальных сообщений выражает «же¬ 
лание» источника этого сообщения принимать глобальные 
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(предназначенные для всех процессоров) директивы. Сообще¬ 
ния о необходимости входа в тот или иной режим работы вы¬ 
нуждают процессор (процессоры) приостановить обслуживание 
текущего процесса и предоставить последний в распоряжение 
соответствующего порта диспетчеризации. Как указывалось, все 
процессоры снабжены соответствующей кэш-памятью, содержа¬ 
щей адресную информацию; для того чтобы сделать эту ин¬ 
формацию недействительной, используются соответствующие 
директивы. 

В процессе выполнения команд процессоры постоянно обнов¬ 
ляют («поддерживают») информацию о текущем контексте, те¬ 
кущем процессе и процессоре как объекте архитектуры системы. 
Сообщения типа «приостановить работу и установить заново 
информацию процессора» заставляют процессор или процессо¬ 
ры обновить некоторую часть указанной информации, обраща¬ 
ясь за необходимыми данными к объектам в памяти. Подобные 
сообщения —директивы — организованы в виде некоторой ие¬ 
рархической структуры (например, директива об обновлении 
информации процессора влечет за собой модификацию процес¬ 
сором информации контекста и процесса) и в большинстве слу¬ 
чаев делают недействительным содержимое соответствующей 
кэш-памяти. 

Каждое сообщение, передаваемое через шину пакетов памя¬ 
ти, состоит из кода — директивы и идентификатора процессо¬ 
ра— источника сообщения. Подтверждение о том, что передан¬ 
ное межпроцессорное сообщение принято, регистрируется. Так, 
в соответствии с рис. 17.12, чтобы передать глобальное сообще¬ 
ние, процессор прежде всего копирует содержимое поля «счет¬ 
чик числа процессоров» в поле «счетчик откликов» сегмента 
данных для глобальных связей. Каждый процессор подтверж¬ 
дает прием сообщения, уменьшая на 1 содержимое поля «счет¬ 
чик откликов». Для сообщений, посылаемых только одному про¬ 
цессору, все выполняется аналогичным образом, за исключени¬ 
ем того, что содержимому счетчика откликов сегмента данных 
для локальных связей первоначально присваивается значение, 
равное 1. 


КОММУНИКАЦИИ МЕЖДУ ПРОЦЕССАМИ 
И ИХ СИНХРОНИЗАЦИЯ 

В системе іАРХ 432 имеется несколько возможностей для пере¬ 
мещения данных и их совместного использования процессами: 
средства передачи/приема (использующие порты связи), сред¬ 
ства блокировки объектов, а также так называемые неделимые 
команды чтения/записи. 



ПРОЦЕССОР ОБЩЕГО НАЗНАЧЕНИЯ ІАРХ 


109 


ПОРТ связи 

Порт связи представляет собой пример возможной реализации 
объекта «порт» (см. рис. 17.2). Порт связи (называемый в 
дальнейшем для краткости просто портом) используется для 
обмена сообщениями между процессами. Роль сообщения мо¬ 
жет выполнять одиночный объект любого типа. Так, сообщени¬ 
ем может быть сегмент доступа или данных общего назначе¬ 
ния, домен, процесс, процессор и т. д. Из системных прав, имею¬ 
щихся в дескрипторе доступа, к порту относятся следующие: 
возможность передачи сообщения порту и возможность прие¬ 
ма сообщений из порта. 

Согласно архитектуре системы іАРХ 432, тот, кто создает 
некоторый порт, ответствен за выделение фиксированного объ¬ 
ема памяти для очередей как в сегменте данных порта, так 
и в его сегменте доступа. Для каждого элемента, поступающего 
в очередь порта, дескриптор доступа в сегменте доступа этого 
порта содержит указатель на этот элемент, а 8-байтовый эле¬ 
мент в сегменте данных описывает индекс следующего элемен¬ 
та этого сегмента, параметры приоритета или гарантированного 
срока обслуживания. Порты связи и диспетчеризации — это раз¬ 
новидности объекта «порт», и поэтому на них распространяется 
действие правил организации и обслуживания очередей. Так же 
как и рассмотренные выше порты диспетчеризации, каждый 
порт связи может быть создан с указанием одного из двух 
правил организации очередей: «поступивший первым —обраба¬ 
тывается первым» или «приоритет — ГСО». Параметры плани¬ 
рования передачи процессов используются для определения по¬ 
рядка передачи/приема сообщений. 

Для работы с портами служат две основные команды — 
SEND и RECEIVE. Команда SEND имеет два операнда: де¬ 
скриптор доступа для порта и дескриптор доступа для объек¬ 
та, подлежащего передаче в качестве сообщения. Если в пор¬ 
те в пространстве, предоставленном для очереди, имеется место, 
то дескриптор доступа для сообщения вставляется в сегмент 
доступа порта, параметры планирования посылающего процес¬ 
са— в элемент очереди сегмента данных порта, а очередь под¬ 
вергается реорганизации, если это необходимо. На этой стадии 
работы процесс не блокируется; его выполнение продолжается. 
Если же пространство, предоставляемое очереди, заполнено 
(или не существует), то выполняются следующие действия. 
Транспортер процесса помещается в конец списка транспорте¬ 
ров (начало и конец которого находятся в сегменте доступа 
порта). Он остается в этом списке до тех пор, пока не появит¬ 
ся место в пространстве, предназначенном для очереди. На 
этой стадии посылающий процесс блокируется до тех пор, по¬ 
ка не появится место в упомянутом пространстве или — в слу- 



110 ГЛАВА 


чае отсутствия самого пространства — пока другой процесс не 
осуществит прием из данного порта. (Когда блокировка сни¬ 
мается, процессор автоматически посылает процесс в соответ¬ 
ствующий порт диспетчеризации. Если этот порт пуст, а некото¬ 
рый процессор находится в очереди к нему, ожидая работы, те 
процессор посылает сообщение упомянутому процессору о по¬ 
будке бездействующего процессора.) При любом удалении ка¬ 
кого-либо объекта из очереди порта процессор проверяет спи¬ 
сок транспортеров, упорядочиваемых по мере их прибытия 
извне. Если список не пуст, то процессор удаляет из него пер¬ 
вый транспортер и помещает транспортируемый объект в оче¬ 
редь порта в соответствии с правилами организации очередей. 

Команда RECEIVE содержит один операнд — дескриптор 
доступа порта. Если сообщение попадает в очередь порта, его 
дескриптор доступа удаляется и помещается в сегмент доступа 
транспортера принимающего процесса. Если сообщений нет, 
транспортер процесса используется для помещения этого про¬ 
цесса в очередь порта согласно правилу обслуживания «посту¬ 
пивший первым — обрабатывается первым», после чего процесс 
блокируется. 

Для работы с портом связи используются две дополнитель¬ 
ные команды (CONDITIONAL-SEND и CONDITIONAL- 
RECEIVE), каждая из которых располагает дополнительным 
операндом — логической (символьной) величиной. Первая из 
этих команд присваивает этой логической величине значение 
«ложно», если очередь порта заполнена и, следовательно, тре¬ 
буется поместить транспортер в очередь и заблокировать про¬ 
цесс. Вторая из названных команд действует подобно команде 
RECEIVE, если на входе порта имеется сообщение; в против¬ 
ном случае процесс не блокируется, а указанной логической 
величине присваивается значение «ложно». 


ЗАМЕНИТЕЛИ СРЕДСТВ ПЕРЕДАЧИ/ПРИЕМА 

Язык Ада располагает возможностями, обычно не предоставляе¬ 
мыми средствами передачи сообщений: принимать сообщения 
одновременно из нескольких портов. Например, согласно фраг¬ 
менту программы на языке Ада, 

select 

accept READ1 (R: in MASTER-RECORD) do 
end READ 1; 

accept READ2 (P: out UPDATE-RECORD) do 

end READ2; 
end select; 
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задача должна ждать появления обоих входных элементов 
READ1 и READ2 (которые могли бы быть представлены как 
порты связи). Для решения подобной проблемы в системе 
іАРХ 432 предусмотрено использование так называемого транс¬ 
портера-заменителя (surrogate carrier) 1 ). В данном случае по¬ 
требовалось бы два таких транспортера в дополнение к «обыч¬ 
ному» транспортеру, связанному с объектом «процесс». 

Команда SURROGATE-RECEIVE помещает в очередь пор¬ 
та не принимающий процесс, а принимающий транспортер-за¬ 
менитель. Последний содержит дескриптор доступа к процессу 
и дескриптор доступа к вторичному порту. Когда что-либо по¬ 
сылается в первый порт и процессор узнает, что принимающей 
стороной является не процесс, а транспортер-заменитель, то 
этот процессор отсылает последний к вторичному порту. Чтобы 
иметь возможность ожидать сообщения из двух портов А и В 
одновременно, процесс инициирует транспортеры-заменители 
для указанных портов с назначением для этих транспортеров 
некоторого порта С в качестве вторичного порта. После этого 
инициируется обычный прием сообщений портом С и процессор 
ждет, когда будет получена информация из соответствующего 
транспортера-заменителя. Эта информация содержит дескриптор 
доступа к передаваемому сообщению. 

Команда SURROGATE-SEND посылает сообщение при лю¬ 
бых условиях без блокировки процесса, используя транспортер- 
заменитель в качестве транспортера сообщения. Когда порт 
связи располагает достаточным местом для сообщения, транс¬ 
портер автоматически пересылается к соответствующему пунк¬ 
ту назначения (порту). 


БЛОКИРОВАНИЕ ОБЪЕКТОВ 

Из описания некоторых объектов, рассмотренных в предыду¬ 
щих разделах, следует, что в системе іАРХ 432 имеется возмож¬ 
ность блокирования объектов. Для этой цели используются 
первые 16 бит следующих сегментов данных: процессора, транс¬ 
портера процессора, локальных связей, глобальных связей, про¬ 
цесса, транспортера процесса, транспортера-заменителя, порта 
(любого типа). Шестнадцатибитовое поле для блокирования 


•> Объект «транспортер-заменитель» подобен по структуре объекту 
«транспортер процесса». Различия между ними заключаются в следующем: 

1) транспортер-заменитель может содержать информацию о планировании 
передачи и приема сообщений; транспортер процесса на это права не имеет; 

2) каждому процессу соответствует один объект «транспортер процесса»; 
объект «транспортер-заменитель» не обязательно автоматически связан с про¬ 
цессами, в то же время одному процессу может принадлежать несколько 
таких объектов. — Прим. ред. 
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объектов имеется и в сегменте данных ресурсов памяти. Кро¬ 
ме того, программам предоставляется возможность использо¬ 
вать любую область памяти соответствующего размера в дру¬ 
гих сегментах данных для записи информации о том, заблоки¬ 
рован данный объект в настоящий момент времени или нет. 
Необходимо подчеркнуть, что блокирование и деблокирование 
объектов осуществляется как программными, так и аппарат¬ 
ными средствами системы. Программными средствами блокиро¬ 
вания и деблокирования объектов являются команды LOCK- 
OBJECT и UNLOCK-OBJECT соответственно. Во многих слу¬ 
чаях аппаратные средства процессора используют те же логи¬ 
ческие схемы, которые реализуют указанные команды. 

Необходимость в синхронизации одновременно протекающих 
процессов не вызывает сомнений, но необходимость в синхро¬ 
низации работы аппаратных средств или аппаратных средств и 
программного обеспечения не столь очевидна. Рассмотрим си¬ 
стему, в которой группа процессоров пользуется единственным 
портом диспетчеризации. Когда один процессор берет некото¬ 
рый процесс из этого порта (что является неявно заданной опе¬ 
рацией), необходимо гарантировать такой режим работы дру¬ 
гих процессоров, при котором в это время они даже не пыта¬ 
лись бы манипулировать портом. Для этой цели первый упомя¬ 
нутый процессор прежде всего проверит, заблокирован ли порт, 
и, если нет, выполнит его блокирование, воспользуется этим 
портом и по окончании работы с ним деблокирует его. Если 
же при обращении к порту процессор обнаружит, что порт за¬ 
блокирован, процессор будет повторять проверку состояния пор¬ 
та до тех пор, пока последний не окажется свободным. 

Необходима также и синхронизация между аппаратно реа¬ 
лизованными процессорами и программно реализуемыми про¬ 
цессами. И в этом случае рассмотрим в качестве примера ра¬ 
боту порта диспетчеризации, принимая во внимание, что процес¬ 
соры неявным образом используют информацию о структуре 
данных, которые могут анализироваться и реорганизовываться 
программными средствами. Так, если операционной системе 
необходимо произвести некоторые манипуляции с очередью про¬ 
цессов в порту диспетчеризации, она должна заблокировать 
порт для гарантии, что процессоры не пользуются им одно¬ 
временно. 

Для блокирования объектов используется последователь¬ 
ность 16 бит, состоящая из 2-битового кода блокировки и 
14-битового идентификатора «блокировщика». Двухбитовый 
код может принимать следующие значения: 00 — объект не бло¬ 
кирован; 01 — блокирован (аппаратными средствами путем вы¬ 
полнения неявно заданной операции); 10 — блокирован (про¬ 
граммными средствами с помощью команды LOCK-OBJECT); 
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11 — блокирован (аппаратными средствами во время выпол¬ 
нения явно заданной операции, например посредством команды 
SEND, посылающей сообщение в порт). При блокировании 
аппаратными средствами идентификатор блокирующего процес¬ 
сора помещается в 14-битовое поле идентификатора, при блоки¬ 
ровании программными средствами это поле можно использо¬ 
вать для хранения идентификатора блокирующего процесса. 

НЕДЕЛИМЫЕ ОПЕРАЦИИ ЧТЕНИЯ/ЗАПИСИ 

Несколько команд, используемых для извлечения операндов 
из памяти или записи в нее результата, определены таким об¬ 
разом, что во время выполнения этих команд производится бло¬ 
кировка памяти. К таким командам относится, например, 
команда INDIVISIBLY-ADD-ORDINAL, при выполнении кото¬ 
рой из памяти извлекаются две 32-битовые величины без зна¬ 
ка, складываются, а затем записывается результат; при этом 
гарантируется, что в течение всех этих операций исходные опе¬ 
ранды не извлекаются и не модифицируются другим процессо¬ 
ром. Данная команда позволяет, например, группе процессов 
обновлять совместно используемый счетчик. 

ОБЪЕКТЫ, ТИП КОТОРЫХ ОПРЕДЕЛЯЕТСЯ 
ПРОГРАММНЫМИ СРЕДСТВАМИ 

Рассмотрим еще одну возможность, предоставляемую системой' 
іАРХ 432 для защиты объектов от несанкционированного до¬ 
ступа. Система позволяет «запечатать» некоторый произволь¬ 
ный объект таким образом, что им могут манипулировать толь¬ 
ко те подпрограммы, которым предоставляется право «распеча¬ 
тать» объект (например, подпрограммы домена, представляю¬ 
щего спецификатор типа для данного объекта). Такая возмож¬ 
ность реализуется посредством объектов «определение типа» 
и дескриптора типа в таблице объектов. Каждый объект, за¬ 
щищенный подобными средствами, называется объектом рас¬ 
ширенного типа или объектом, тип которого определяется поль¬ 
зователем. 

Эти средства схематически изображены на рис. 17.16. Поло¬ 
жим, что имеется объект А, который нужно защитить таким об¬ 
разом, чтобы непосредственно оперировать им имели возмож¬ 
ность только те подпрограммы, которые находятся в домене 
XOPS. Иначе говоря, программам разрешается иметь дескрип¬ 
торы доступа, которые представляют объект А, но только ука¬ 
занный домен может манипулировать объектом А или наблю¬ 
дать его состояние. Более того, этому домену разрешается ма¬ 
нипулировать только этим объектом или другими идентичными 


8—429 




114 ГЛАВА 17 



Рис. 17.16. Адресация объекта расширенного типа. (* — Обычно к домену 
для спецификатора типа объекта для объектов типа X.) 

структурами (в дальнейшем будем условно называть их струк¬ 
турой типа X). 

Положим, что существует домен XOPS, а также объект 
«определение типа», представляющий структуру типа X. Упомя¬ 
нутый объект — это системный объект, состоящий из сегмента 
доступа. Последний не имеет заранее определенного содержи¬ 
мого, но, как правило, действует соглашение, по которому этот 
сегмент содержит дескриптор доступа к домену XOPS. Одной 
из подпрограмм, связанной с этим доменом, может быть под¬ 
программа CREATE-X-OBJECT. Ее функцией является созда¬ 
ние объекта типаХ и возврат по адресу вызова дескриптора до¬ 
ступа, представляющего этот объект. После создания объекта А 
(т. е. объекта типа X) посредством команды CREATE-DATA- 
SEGMENT или CREATE-ACCESS-SEGMENT (что делает объ¬ 
ект А фактически сегментом доступа или сегментом данных об¬ 
щего назначения) подпрограмма CREATE-X-OBJECT выпол¬ 
няет команду CREATE-PRIVATE-TYPE. Двумя операндами 
этой команды являются дескрипторы доступа для объекта «оп- 




ПРОЦЕССОР ОБЩЕГО НАЗНАЧЕНИЯ ІАРХ 


115 


I дд для объекта 
расширенного 


Законсервировано 



\ Законсервировано 


Общее/частное —I 
вит готовности -' 


Рис. 17.17. Представление дескриптора типа в таблице объектов. 


ределение типа» и объекта А. Эта команда создает дескриптор 
типа в таблице объектов, связывая объект А и объект «опреде¬ 
ление типа», а также создает дескриптор доступа (ДД) к дес¬ 
криптору типа. 

Дескриптор типа, размещающийся в таблице объектов, по¬ 
казан на рис. 17.17. Он содержит дескрипторы доступа для са¬ 
мого объекта, а также для объекта «определение типа». ДД к 
объекту «определение типа» принято называть дескриптором до¬ 
ступа к объекту расширенного типа. Этого дескриптора недо¬ 
статочно для выполнения операций над соответствующим объ¬ 
ектом, даже если дескриптор и содержит все права доступа; не¬ 
обходимо располагать ДД к самому объекту. Если объект был 
создан как объект частного пользования (индикатором этого 
является флаг в дескрипторе типа), ДД к нему может быть по¬ 
лучен посредством выполнения команды RETRIEVE-TYPE- 
REPRESENTATION. Однако указанной команде в качестве 
операндов требуются ДД к объекту расширенного типа и ДД к 
объекту «определение типа». Более того, объект «определение 
типа» должен соответствовать объекту расширенного типа, 
указанному в дескрипторе типа. Следовательно, если специфика¬ 
тор типа объекта (XOPS) содержит ДД к объекту «определе¬ 
ние типа», являющийся внутренним по отношению к самому се¬ 
бе (например, в его домене), только XOPS может непосредст¬ 
венно выполнять операции над объектом расширенного типа. 

Мы рассмотрели обычное решение проблемы защиты объ¬ 
ектов специального типа от несанкционированного доступа — 
посредством спецификатора типа объекта. Наряду с этим си¬ 
стема предоставляет еще два возможных решения этой про¬ 
блемы. Первое решение предполагает создание объекта рас¬ 
ширенного типа общего пользования (в противоположность 
объектам частного пользования), что связано с применением 
команды CREATE-PUBLIC-TYPE. Такой объект имеет также 
объект «определение типа», а возможно, и спецификатор типа. 
Однако в этом случае нет ограничений на получение ДД к са¬ 
мому объекту; достаточно располагать ДД к объекту расширен¬ 
ного типа и выполнить команду RETRIEVE-PUBLIC-TYPE- 
REPRESENTATION. Результат выполнения этой команды подо- 


8 » 




116 ГЛАВА 


€ен результату команды RETRIEVE-TYPE-REPRESENTATION, 
однако в данном случае не требуется ДД к объекту «определе¬ 
ние типа». 

Второе решение указанной выше проблемы позволяет пу¬ 
тем некоторой процедуры выбора получать ДД к объек¬ 
ту расширенного типа. Известно, что одним из системных 
прав в ДД к объекту расширенного типа является право брать 
обратно ДД к объекту «определение типа». Если имеющийся 
в распоряжении ДД обладает таким правом, можно выполнить 
команду RETRIEVE-TYPE-DEF.INITION, а затем команду 
RETRIEVE-TYPE-REPRESENTATION. 

Объектом расширенного типа можно сделать объект любого 
типа, включая системные объекты и объекты, которые уже яв¬ 
ляются объектами расширенного типа. 

УПРАВЛЕНИЕ ПАМЯТЬЮ 

В дополнение к возможностям управления объектами и адре¬ 
сации к ним система іАРХ 432 предоставляет средства для 
управления свободной памятью (т. е. памятью, не используе¬ 
мой в текущее время для представления объекта) и выполне¬ 
ния процедуры «сбора мусора» в памяти, занимаемой неисполь¬ 
зуемыми объектами. Многие ранее упоминавшиеся понятия ар¬ 
хитектуры системы іАРХ 432 имеют отношение к выделению 
памяти: объект «ресурсы памяти», команды CREATE-ACCESS- 
SEGMENT и CREATE-DATA-SEGMENT, хип-флаг в дескрип¬ 
торах доступа, заголовок таблицы объектов, данные объекта 
«локальные ресурсы памяти» в сегменте данных процесса, 
команда CALL. С упомянутой процедурой «сбора мусора» свя¬ 
заны следующие понятия: хип-флаг в дескрипторах доступа, 
номер уровня в дескрипторах объектов, флаг повторного за¬ 
проса в дескрипторах объектов, команда RETURN. 

Память, имеющаяся в распоряжении для выделения объ¬ 
ектам, представлена в архитектуре системы іАРХ 432 объекта¬ 
ми «ресурсы памяти», структура которых показана на рис. 17.18. 
У этих объектов нет фиксированных взаимосвязей с процессами, 
процессорами, таблицами объектов и т. п. Количество объек¬ 
тов «ресурсы памяти» в системе и их назначение определяются 
программными средствами. Сегмент данных такого объекта со¬ 
держит один или несколько дескрипторов блоков памяти, каж¬ 
дый из которых определяет свободный блок смежных областей 
памяти путем указания адресов первого и последнего байтов 
блока (эти байты должны принадлежать 8-байтовым границам 
памяти). Сегмент данных указывает также индексы первого и 
текущего (определяемого в дальнейшем) дескрипторов блоков 
памяти. 
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Команды CREATE-DATA-SEGMENT и CREATE-ACCESS- 
SEGMENT присваивают имя объекту «ресурсы памяти» как од¬ 
ному из своих операндов. Машина использует такой объект в 
качестве источника памяти, необходимой для представления 
объекта. 

Отметим, что объект «процесс» (рис. 17.13) содержит об¬ 
ласть памяти, помеченную как область объекта «локальные ре¬ 
сурсы памяти» и похожую на сегмент данных объекта «ресур¬ 
сы памяти» с единственным дескриптором блока памяти. Этот 
локальный объект «ресурсы памяти» определяет область адрес¬ 
ного пространства, которая может быть использована процессом 
для размещения локальных объектов (например, таким обра¬ 
зом машина может выделить место для контекста). 

Упомянутые выше команды создания сегментов могут обра¬ 
щаться к объекту «ресурсы памяти» или объекту «локальные 
ресурсы памяти» (в последнем случае используется селектор 
операнда 0 в поле операнда команды). В первом случае сегмент 
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Рис. 17.18. Представление объекта «ресурсы памяти». 
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считается выделенным из общей, не связанной с процессом па¬ 
мяти (хип-памяти). Это предполагает освобождение этой памя¬ 
ти неявным образом при возвращении из подпрограммы. Хип- 
флаг в новом дескрипторе доступа устанавливается в 1, тем 
самым указывая, что общая (глобальная) память была исполь¬ 
зована для адресуемого сегмента. По тем же причинам в поле 
номера уровня в новом дескрипторе объекта записывается 0. 

Когда процесс создает сегмент, используя данные своего 
объекта «локальные ресурсы памяти», хип-флаг в новом деск¬ 
рипторе доступа устанавливается в положение 0, а номер уров¬ 
ня в новом дескрипторе объекта принимает значение, соответ¬ 
ствующее текущему контексту в процессе (т. е. значение теку¬ 
щего числа вложенных активаций подпрограммы). 

Когда машина адресуется к объекту «ресурсы памяти» для 
выделения последней, используется специальный алгоритм. 
(Алгоритм для выделения памяти из объекта «локальные ре¬ 
сурсы памяти» процесса является тривиальным, поскольку в 
этом случае имеется только один дескриптор блока памяти). 
Этот алгоритм получил название циклический поиск первого 
подходящего случая; циклический поиск является причиной на¬ 
личия индекса текущего блока в сегменте данных объекта «ре¬ 
сурсы памяти». Процессор выполняет просмотр дескрипторов 
блоков памяти в поисках ближайшего, подходящего по объему. 
Начинается поиск с того дескриптора, который указан индек¬ 
сом текущего блока, и возобновляется, если необходимо, пере¬ 
ходом от последнего дескриптора снова к указанному первому. 
Когда подходящий блок найден, дескриптор блока памяти 
обновляется, что отображает факт удаления памяти, а индекс 
текущего блока получает приращение. Если подходящий блок 
обнаружить не удается, выдается сообщение об ошибке. 

После выделения памяти создаются дескриптор объекта (по¬ 
средством заголовка таблицы объектов, позволяющего обнару¬ 
жить свободный дескриптор) и дескриптор доступа. Затем осу¬ 
ществляется инициализация сегмента, т. е. присваивается со¬ 
держимое в виде нулей, если это сегмент данных, или присваи¬ 
вается нулевое значение биту младшего разряда — биту готов¬ 
ности— каждого 32-битового слова, если это сегмент доступа. 

Во всех случаях содержимое поля повторного запроса па¬ 
мяти в заголовке таблицы объектов сначала проверяется, а за¬ 
тем уменьшается на величину выделенной памяти. Если резуль¬ 
тат такого вычитания становится отрицательным числом, вы¬ 
дается сообщение об ошибке. 

«СБОР МУСОРА» в ПАМЯТИ 

Архитектурой системы іАРХ 432 предусмотрена возможность 
выполнения неявным образом задаваемой операции «сбора му- 
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сора» применительно клональным объектам. Кроме того, систе¬ 
ма предоставляет программные средства для подобной операции 
сбора хип-объектов (т. е. объектов продолжительного времени 
существования). Когда выполняется команда RETURN, ма¬ 
шина повторно запрашивает всю память, связанную с объек¬ 
тами, номера уровней которых больше или равны номеру уров¬ 
ня текущего контекста. Это осуществляется путем поиска ме¬ 
стоположения объектов посредством текущей таблицы объек¬ 
тов данного процесса. 

Казалось бы, это должно создавать проблему не имеющих 
адресата ссылок, например в случае, когда контекст возвраща¬ 
ет дескриптор доступа к локальному объекту в качестве пара¬ 
метра или когда он записывает дескриптор доступа к локаль¬ 
ному объекту в хип-объект. Однако архитектура системы 
іАРХ 432 исключает возникновение подобных проблем. Если 
хип-флаг дескриптора доступа не установлен в 1, этот дескрип¬ 
тор не может быть записан в сегмент, номер уровня которого 
меньше номера уровня текущего контекста. 

Что же касается хип-объектов, то, согласно их определению 
как объектов продолжительного времени существования, пробле¬ 
ма ссылок, не имеющих адресата, для них не возникает. Отме¬ 
тим, что принципы архитектуры системы іАРХ 432 базируются 
на существовании программно реализуемого алгоритма поиска 
и «сбора» областей памяти, занимаемых объектами, возмож¬ 
ность адресации к которым утеряна. Этот алгоритм представ¬ 
ляет собой описание процесса, состоящего из двух фаз и про¬ 
текающего одновременно с другими процессами системы; его 
функции — идентификация и сбор сегментов, не имеющих ссы¬ 
лок [1]. Алгоритм предъявляет к системе адресации только 
одно требование — иметь возможность помечать (выставлять 
«серый флаг») сегмент, адрес которого зарегистрирован. Для 
этой цели используется флаг повторного запроса памяти в де¬ 
скрипторах в таблице объектов. Соответствующему биту про¬ 
цессор присваивает значение 1 при создании или копировании 
дескриптора доступа, связанного с тем или иным элементом таб¬ 
лицы объектов. 

ОБРАБОТКА ОШИБОК 

В архитектуре системы іАРХ 432 предусмотрены средства об¬ 
работки ошибок (обнаруживаемых машиной), которые возни¬ 
кают при работе процессора, а также выполнении операций 
процесса и контекста. При этом система выдает достаточно 
полную информацию об ошибке, позволяющую программе об¬ 
работки ошибок выполнить коррекцию и продолжить выполне¬ 
ние программы. 
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В соответствии с «многоуровневым» описанием функциони¬ 
рования системы (уровень контекста, процесса, процессора) 
ошибки подразделяют на ошибки на уровне процессора, процес¬ 
са и контекста. Ошибки на уровне контекста порождаются про¬ 
граммными ошибками (например, ошибки выполнения вычисле¬ 
ний, индексирования, неполного задания объекту необходимых 
прав). Каждый объект «команды» в соответствующем ему объ¬ 
екте «домен» содержит индекс дескриптора доступа другого 
объекта «команды» (программы обработки ошибок), которо¬ 
му следует передать управление при возникновении ошибок на 
уровне контекста. Войти в программу обработки ошибок мож¬ 
но посредством неявно заданной команды перехода; при этом 
команды программы обработки ошибок выполняются как часть- 
текущего контекста. В сегменте данных контекста имеется об¬ 
ласть хранения информации об ошибке, куда и помещаются 
сведения об обнаруженной ошибке. После выполнения этих дей¬ 
ствий ответственность за обработку ошибки на уровне контекста 
возлагается на объект «команды обработки ошибок». Если упо¬ 
мянутый выше объект «команды» не указывает на подобную- 
программу обработки ошибок, то ошибка на уровне контекста 
становится ошибкой на уровне процесса. 

Отличительными признаками ошибок на уровне процесса яв¬ 
ляются следующие: 1) взаимосвязь с «окружением» процесса 
в системе во время его протекания (например, с информацией 
о блокировании объектов, об управлении памятью, о присутст¬ 
вии в системных объектах информации, не соответствующей 
данным условиям протекания процесса) или 2) принадлежность 
к ошибкам на уровне контекста, для которых объект «коман¬ 
ды» не указывает программу обработки ошибок. Специфичным 
является и способ обработки ошибок на уровне процесса. Каж¬ 
дый сегмент доступа процесса (рис. 17.13) может содержать 
дескриптор доступа, адресующийся к порту ошибок. При воз¬ 
никновении ошибки на уровне процесса в область информации 
об ошибке в объекте «процесс» записывается некоторое значе¬ 
ние, и процессор выполняет неявно заданную операцию пере¬ 
сылки объекта «процесс» как сообщения в порт ошибок. Затем 
процессор опрашивает свой порт диспетчеризации в поисках 
другого процесса. В операционной системе будет находиться 
процесс —программа обработки ошибок, принимающий содер¬ 
жащие ошибки процессы из упомянутого порта ошибок (пред¬ 
ставляющего собой нормальный порт связи). 

В поле состояния сегмента данных процесса имеется флаг, 
указывающий на необходимость обработки ошибок на уровне 
процесса как ошибок на уровне контекста. 

К ошибкам на уровне процессора относятся, во-первых, 
сшибки, вызываемые машинными (аппаратными) сбоями; во- 
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вторых, ошибки, возникающие, когда у процессора нет назна¬ 
ченного ему процесса (например, ошибки, связанные с функцио¬ 
нированием порта диспетчеризации); в-третьих, ошибки на уров¬ 
не процесса, которые не поддаются обработке (например, если 
либо не указан порт ошибок для процесса, либо возникает 
ошибка при выполнении неявно задаваемой операции пересылки 
содержащего ошибку процесса, либо оказывается заполненной 
очередь в порту ошибок). 

При возникновении ошибок на уровне процессора соответ¬ 
ствующая информация помещается в область информации об 
ошибке в сегменте данных процессора. Процессор отыскивает 
свой порт диагностики, указываемый в объекте «процессор», 
и посылает процесс диагностики в очередь этого порта. Если 
процессор располагает назначенным ему процессом, последний 
не помещается в очередь порта диспетчеризации. 

Нельзя, конечно, исключать возможность неудачного выпол¬ 
нения описанных выше процедур (например, вследствие отка¬ 
зов в работе электронных схем процессора, отсутствия порта 
диагностики, сбоев в процессе адресации процессора к порту 
диагностики). В таком случае имеет место прекращение рабо¬ 
ты процессора — его останов, что сопровождается формирова¬ 
нием соответствующего сигнала на специальном выводе. 


типы ошибок 


Ниже перечисляются некоторые виды ошибок и уровни, на ко¬ 
торых они имеют место. 


Уровень 


Название 


ошибки 


Переполнение индекса при масштабировании 
Переполнение смещения при адресации 
Переполнение указателя команды 

Наличие ошибки в домене (недопустимый класс, деление на 
нуль) 

Переполнение 
Антипереполнение 
Недостаточная точность 

Недопустимый системный тип (несоответствие типа коман¬ 
ды/объекта) 

Переполнение сегмента 
Переполнение памяти 
Нарушение прав на чтение 
Нарушение прав на запись 

Некорректное использование прав доступа к адресату сегмен¬ 
та доступа 

Неудачная попытка обработки ошибок на уровне контекста 
Наличие ошибки в дескрипторе объекта 

Недействительность дескриптора доступа (неопределенный 

ДД) 
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Уровень 


Название ошибки 


Процесс 


Преждевременное использование права на удаление адресата 
Переполнение индекса объекта «команды» 

Антипереполнение запроса памяти в заголовке таблицы объ¬ 
ектов 

Стирание ДД (путем записи другой информации), флаги уда¬ 
ления которых не сброшены 
Стирание уровня дескриптора доступа 

Выход за пределы допустимых значений индекса входного 
элемента 

Ошибочное указание прав/типа объекта «управление дескрин- 
тором»/«управление аффинажем»/«описание типа» 

Нарушение системных прав 

Неправильное задание размеров параметров контекста 
Преждевременное изменение дескриптора доступа. (В процес¬ 
се выполнения команды AMPLIFY-RIGHTS дескриптор до¬ 
ступа изменяется прежде, чем результат выполнения коман¬ 
ды записывается в память.) 

Нарушение требований блокировки объектов (попытка вы¬ 
полнять операции над системными объектами без блокиро¬ 
вания этих объектов) 

Переполнение аффинажа 

Состояние, при котором исчерпаны все ресурсы дескрипторе* 
объектов 

Наличие неправильного адреса в дескрипторе блока памяти 
Переполнение индекса дескриптора блока памяти 
Фрагментация блока памяти 
Некорректное извлечение команды 

Неудачная попытка обработки ошибки на уровне процесса 
Регистрация ошибки при отсутствии процесса 
Сбои аппаратных средств 


ОБЛАСТЬ ИНФОРМАЦИИ ОБ ОШИБКЕ 

В сегментах данных объектов «процессор» и «процесс» имеется 
область, используемая машиной для описания ошибки. На 
рис. 17.19 показан формат такой области. 

В поле индекса объекта с ошибкой размещается ссылка на 
дескриптор доступа объекта «команды», содержащего ошибку 
и расположенного в домене, который связан с данным объек¬ 
том с ошибкой. Поля указателей стеков предшествующей и по¬ 
следующей команд содержат смещения (в битах) команды, при 
выполнении которой регистрируется ошибка, и следующей за 
ней команды. (Если ошибка возникает до завершения кодиро¬ 
вания команды, содержимое поля указателя последующей 
команды может оказаться непредсказуемым.) Аналогичным 
образом поля указателей стеков предшествующей и последую¬ 
щей команд содержат значения указателя стека операндов со¬ 
ответственно во время начала выполнения команды и при воз¬ 
никновении ошибки. 
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В поле ошибки имеются четыре 
флага, описывающие характеристики Первый операнд- 

команды, при выполнении которой источник 

возникает ошибка, и состояние контек-_ 

ста. Эта информация предназначена второй операнд- 

для программы обработки ошибок. источник или исклю- 
Упомянутые флаги указывают следую- чительныйрезультат 

щее: является ли операнд, адресую- --- 

щий результат выполнения команды, Смещение ошибки _ 

ссылкой на стек или ссылкой на об- Селектор сегмента с ошибкой 
ласть памяти; допускается ли получе- р 0 у ошибки 

ние неточных результатов; заполнен - • - 

ли регистр содержимого вершины сте- ---- 

ка к началу выполнения команды или Поле ошибки 
к моменту возникновения ошибки. у р^шеи Л кома е н^ы превшест ~ 
Если флаг 1 указывает, ЧТО результат Указатель стека последующей 
подлежит пересылке в память, поля предшешвуЮ ще й 

селектора сегмента с ошибкой и сме- команды __ 

щения ошибки содержат информацию юман8ы ь послеа ^ юии ' еа 
соответственно о селекторе сегмента, Индекс объекта с ошибкой 

в котором обнаружена ошибка, и о область информации об - 

смещении в сегменте доступа (или ошибке 
сегменте данных, к которым уже по¬ 
лучен доступ) в момент возникнове- Рис. 17.19. Формат области, 
ния ошибки. содержащей информацию 

Поля первого операнда-источни- «рессор», 

ка и второго операнда — источника р ѵ 

(или результата, соответствующего 

так называемой исключительной ситуации) используются для 
команд выполнения вычислительных операций. Если ошибка 
происходит до выполнения командой соответствующей опера¬ 
ции, то указанные поля содержат значения операндов — источ¬ 
ников. Если же ошибка возникает после формирования резуль¬ 
тата (например, ошибка переполнения), второе из названных 
выше полей содержит результат, представленный в так назы¬ 
ваемой исключительной форме. 

Поле индекса кода операции может быть использовано вме¬ 
сте с соответствующей таблицей кодов операций для опреде¬ 
ления кода операции команды, вызвавшей появление ошибки. 

Поле кода ошибки содержит 16 бит информации о типе 
ошибки. Кодирование этой информации осуществляется по весь¬ 
ма сложному правилу и здесь рассматриваться не будет. В не¬ 
которых случаях информация этого поля подлежит использо¬ 
ванию вместе с информацией о типе команды для определения 
типа ошибки. Для ошибок, связанных с адресацией к памяти, 
это поле содержит индикатор вида операции («чтение» или «за- 
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пись»). Для ошибок, выражающихся в переполнении сегмен¬ 
та, нарушении прав на чтение или запись или несоответствии 
типов команд и объекта, в поле кода ошибки содержится ин¬ 
формация о типе объекта, к которому осуществляется доступ. 

ОСНОВНЫЕ ХАРАКТЕРИСТИКИ 
СИСТЕМЫ іАРХ 432 

Сравним системы іАРХ 432 и SWARD. Их сопоставление ин¬ 
тересно уже потому, что при разработке этих систем были по¬ 
ставлены одни и те же цели (облегчение процесса разработки 
программного обеспечения), а многие основные принципы их 
построения на самом высоком уровне абстракции сходны (на¬ 
пример, в обеих системах используются такие абстрактные по¬ 
нятия, как объекты, потенциальные адреса, одновременно проте¬ 
кающие процессы). Главное различие между этими системами 
заключается в том, что упомянутые принципы построения си¬ 
стемы SWARD представляют собой абстракции, создаваемые 
при реализации машины (речь идет об объектах, таких, как про¬ 
цесс-машины), в то время как подобным абстракциям в систе¬ 
ме іАРХ 432 соответствуют доступные пользователю структуры 
данных. Однако последние с помощью средств операционной 
системы могут быть «скрыты» от пользователя и стать тем са¬ 
мым для них недоступными. На основании подобного сравнения 
двух указанных систем можно сделать следующие (хотя и не 
проверенные на практике, а поэтому умозрительные) заключе¬ 
ния: 

1) архитектура системы SWARD менее сложная, чем архи¬ 
тектура системы іАРХ 432; 

2) аппаратные средства системы іАРХ 432 по своей органи¬ 
зации проще, чем средства системы SWARD; 

3) система SWARD отличается более высоким быстродейст¬ 
вием, поскольку предоставляет больше возможностей по распа¬ 
раллеливанию функций, подлежащих выполнению; 

4) системе іАРХ 432 присуща большая гибкость, перестраи- 
ваемость конфигурации средств; 

5) система іАРХ 432 гарантирует меньший риск отказов по 
сравнению с системой SWARD. 

Применяемое к системе іАРХ 432 утверждение, что это — 
машина операционной системы, наиболее выразительно харак¬ 
теризует специфику данной вычислительной системы. (Иногда 
ее называют машиной высокого уровня языка Ада; однако такое 
определение нельзя признать корректным, поскольку система 
іАРХ 432 обеспечена ограниченными средствами, имеющими 
прямое отношение к реализации языка Ада.) Система іАРХ 432 
располагает обширным набором средств управления памятью, 
планирования процессов и организации коммуникаций между 
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процессами, позволяющим сравнительно легко реализовать ту 
или иную стратегию функционирования операционной системы. 
Ниже перечисляются основные специфические характеристики, 
системы іАРХ 432. 

Описание системы посредством объектов. Такой прием поз¬ 
воляет добиться высокой однородности, регулярности средств 
описания. Например, все компоненты системы (даже такие, как 
процесс или процессор) могут быть представлены объектами 
«сообщение», пересылаемыми через порт. Используя объекты 
как единую форму описания архитектуры системы, удается с 
общих позиций определить взаимосвязь машины, операцион¬ 
ной системы, языка программирования и прикладных программ. 

Использование средств защиты от несанкционированного 
доступа. Система располагает широким набором средств за¬ 
щиты наряду с механизмом потенциальной адресации. Этот на¬ 
бор включает права системы, объекты «управление дескрипто¬ 
ром» и «определение типа». Наиболее мощным средством явля¬ 
ются объекты «управление дескриптором», поскольку они предо¬ 
ставляют широкий выбор вариантов реализации своих воз¬ 
можностей. Например, объект «управление дескриптором» мо¬ 
жет быть определен для создания объектов «порт», расширения 
любых прав доступа, предоставления только права на чтение: 
или использования объектов «процесс». 

Ориентация на работу с программами высокой модульности 
при использовании спецификаторов типов объектов. Многое ив 
того, что положено в основу системы, связано с указанной ори¬ 
ентацией: объекты «домены», «контексты», «определение ти¬ 
па», «аффинаж» и средства расширения прав доступа. 

Наличие параллельных процессов и группы процессоров.. 
Имеются чрезвычайно гибкие разнообразные программные сред¬ 
ства организации их совместной работы. Соответствую¬ 
щие средства, обеспечивающие их функционирование, включа¬ 
ют возможность задания, во-первых, правил организации оче¬ 
редей, специфических для каждого порта; во-вторых, парамет¬ 
ров приоритета и гарантированных средств обслуживания каж¬ 
дого процесса; в-третьих, временного интервала и пределов пе¬ 
риода обслуживания каждого процесса; в-четвертых, порта пла¬ 
нирования. 

Возможность использования одного и того же набора средств 
блокирования объектов как аппаратными, так и программными 
средствами. Эти средства, использование которых в системе 
іАРХ 432 необходимо, являются нововведением в архитектуре 
ЭВМ. 

Однородность архитектуры системы. Предполагается приме¬ 
нимость принципов построения архитектуры системы іАРХ 432 
при системном проектировании разнородных процессоров. (В су- 
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ществующих в настоящее время проектах имеются процессоры 
двух видов —обработки данных общего назначения и интер¬ 
фейсные.) 

Как и в случае системы SWARD, использование языка Ада 
в данной системе наталкивается на определенные несоответст¬ 
вия между требованиями языка и возможностями системы. При¬ 
чиной этого является привязка программ на языке Ада к окру¬ 
жающим их средствам системы уже на ранней стадии обслужи¬ 
вания задания, что в свою очередь объясняется ориентацией 
разработчиков этого языка на традиционные вычислительные 
системы. Например, принцип использования домена (для паке¬ 
тов языка Ада) для описания операций на этапе выполнения, 
потенциальные адреса, объекты расширенного типа, объекты 
«управление дескриптором» и другие компоненты архитектуры 
системы іАРХ 432 оказываются ненужными как средства, окру¬ 
жающие программу на языке Ада, хотя перечисленные компо¬ 
ненты дают возможность создания более динамичного и на¬ 
дежного окружения для программ, чем то, которое запрашива¬ 
ется правилами этого языка. Сотрудники фирмы Intel для ре¬ 
шения этой проблемы предложили расширить некоторые сред¬ 
ства языка Ада с целью реализации последнего в системе 
іАРХ 432 с учетом широких возможностей этой вычислительной 
системы. 

Сравнивая относительное быстродействие рассматриваемых 
вычислительных систем, следует отметить, что в существующем 
прототипе системы SWARD, несмотря на более низкую частоту 
ее тактового генератора и высокую частоту проверки содержи¬ 
мого тегов, программы выполняются несколько быстрее, чем в 
процессоре обработки данных общего назначения (GDP) систе¬ 
мы іАРХ 432. (Однако при рассмотрении отдельных случаев та¬ 
кой вывод может оказаться неверным; так, в системе іАРХ 432 
быстрее выполняются операции арифметики чисел с плаваю¬ 
щей точкой, а система SWARD обеспечивает более высокую 
скорость выполнения операций над строками символов.) Все пе¬ 
речисленное объясняется различиями в архитектурах сравнивае¬ 
мых систем, а также спецификой конкретной реализации каждой 
из них. Что касается архитектуры, то в системе іАРХ 432 объ¬ 
екты (в частности, объект «контекст») представлены как груп¬ 
пы сегментов памяти, что влечет необходимость повторного вы¬ 
деления памяти при обращении к подпрограммам. И если про¬ 
должить сравнение способов обращения к подпрограммам в 
обеих системах, то следует указать, что действия, реализуемые 
командой CALL в системе SWARD, выполняются в системе 
іАРХ 432 с помощью последовательности команд, которые дол¬ 
жен генерировать компилятор (команды для создания списка 
формальных параметров в сообщении, команды присвоения 
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начальных значений локальным переменным и формирования 
сегментов доступа к точкам входа в подпрограмму). 

Продолжив сравнение систем іАРХ 432 и SWARD, следует 
отметить, что первая из них при каждом обращении к данным 
должна решать проблему определения одного или нескольких 
потенциальных адресов путем прохода нескольких уровней кос¬ 
венной адресации, в то время как вторая система не нуждается 
в средствах потенциальной адресации для доступа к локальной 
переменной или к параметру. Для компенсации этих издержек 
адресации в системе іАРХ 432 предусмотрены два ассоциатив¬ 
ных запоминающих устройства преобразования адресных ссы¬ 
лок (см. гл. 18). 

Специфика конкретной реализации той или иной системы за¬ 
трудняет сравнительную оценку их эффективности. Отметив 
только, что в существующем в настоящее время процессоре об¬ 
работки данных общего назначения системы іАРХ 432 исполь¬ 
зуется микропрограмма последовательной организации алгорит¬ 
ма функционирования, тогда как у созданного прототипа систе¬ 
мы SWARD микропрограмма отличается сравнительно высокой 
степенью параллелизма выполнения требуемых функций. 

УПРАЖНЕНИЯ 

17.1. Объясните, с какой целью в дескрипторе доступа осуществляется’ 
разграничение прав объекта и системных прав. 

17.2. Укажите базовый тип сегментов объектов «таблица объектов» в 
«справочник таблиц объектов». 

17.3. Поясните, каким образом операционная система осуществляет пуск 
процесса после того, как ею созданы сегменты, образующие объект «процесс». 

17.4. Дайте ответ, почему по команде SEND осуществляется блокирова¬ 
ние процесса, транспортер которого использован для постановки в очередь- 
сообщения. 

17.5. Спецификатор типа объектов располагает средствами защиты объек¬ 
тов от несанкционированного доступа. Сопоставьте функции используемых 
для этих целей объектов «управление дескриптором» совместно со средства¬ 
ми расширения прав доступа, с одной стороны, и объектов «определение ти¬ 
па», с другой. 

17.6. При выполнении команд CREATE-DATA-SEGMENT и CREATE- 
ACCESS-SEGMENT в таблице объектов создается дескриптор объекта. Ука¬ 
жите, в какой именно таблице из всех возможных таблиц объектов системы. 

17.7. Объясните, с какой целью при создании сегмента доступа машина- 
присваивает значение 1 младшему биту 32-битового слова. 

17.8. Укажите, в каких случаях возникает ситуация, при которой про¬ 
грамме желательно указывать в соответствующем объекте «процесс», что- 
ошибки на уровне процесса следует воспринимать как ошибки на уровне 
контекста. 

17.9. Поясните, в каких ситуациях сегмент команд, обрабатывающих 
ошибки, может использовать команду SET-CONTEXT-MODE. 
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ОБЩЕГО НАЗНАЧЕНИЯ іАРХ 432 


В данной главе рассматриваются форматы и назначение команд 
процессора общего назначения системы іАРХ 432. В послед¬ 
нем разделе описывается адресная информация, хранимая в 
■блоках ассоциативной памяти, используемых для преобразова¬ 
ния адресов. 


ФОРМАТЫ КОМАНД 

Все машинные команды системы іАРХ 432 имеют один и тот 
же формат (рис. 18.1). Каждая команда представляется че¬ 
тырьмя полями. Первым является поле класса команды. В нем 
определяется число операндов и их размеры. Во втором поле — 
так называемом поле формата — задается порядок размещения 
«операндов и указывается, представлены они адресами данных в 
памяти или находятся в стеке. Третье поле — поле адресов дан¬ 
ных или адресов перехода. Четвертое поле содержит код выпол¬ 
няемой операции (КОП). Содержимое поля класса и содержи¬ 
мое поля КОП не являются независимыми; в вычислительных 
системах другой архитектуры содержимое этих полей обычно 
объединено и занимает поле КОП. Наибольшая допустимая дли¬ 
на команды равна 321 бит, наименьшая — 6 бит. 

Принятый формат команд призван оптимизировать кодиро¬ 
вание данных и интерпретацию команды при ее выполнении. 
Как отмечалось выше, команды могут размещаться в сегменте 
команд со смещением на произвольное число битов. Процессор 
анализирует содержимое поля класса команды и определяет 
число операндов и их размеры. После того как посредством та¬ 
кого анализа будут извлечены операнды, выполняется анализ 
КОП и выясняется, что именно должно быть сделано с операн¬ 
дами: вычислена сумма, произведение и т. п. В табл. 18.1 при¬ 
ведено возможное содержимое поля класса команды. 
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Поле 

нласса 

1 Поле 
і формата 

Поле адресов данных и адресов перехода 

ПОП 

4-6 бит 

0-4 бит 

0-306 бит 

0-5 бит 


_ Увеличение 

адреса 


Рис. 18.1. Формат команд системы іАРХ 432. 


Содержимое поля формата определяет следующее: 1) пред¬ 
ставляет ли операнд обращение к данным из основной памяти 
или является указателем на необходимость извлечения операнда 
из стека (в последнем случае соответствующий операнд коман¬ 
ды не является адресом данных); 2) какова позиция в коман¬ 
де обращения к данным, которая соответствует определенному 
операнду (например, первому операнду команды ADD-INTEGER 
не обязательно должен соответствовать первый адрес данных в 
этой команде). Возможное содержимое поля формата приве¬ 
дено в табл. 18.2. Содержимое поля формата взаимосвязано с 
содержимым поля класса команды. Так, длина поля формата 
зависит от числа операндов, производящих обращение к дан¬ 
ным (в отличие от адресов перехода). Это число определяется 
в поле класса команды. Если в команде нет операндов, адресу- 
Таблица 18.1. Содержимое поля класса команды 


Содержимое поля 

Размеры операндов 

Содержимое поля 

Размеры операнде» 

001110 

Отсутствуют ' 

101101 

64 

80 


101110 

Адрес 

: перехода 

011101 

80 

8 


0000 

8 адрес перехода 

111101 

80 

32 


011110 

8 


000011 

80 

64 


111110 

16 


100011 

80 

80 


000001 

32 


010011 

8 

8 

8 

100001 

64 


1100 

16 

16 

8 

010001 

80 


0010 

16 

16 

16 ' 

110001 

8 

8 

110011 

16 

16 

32 

001001 

8 

16 

001011 

16 

32 

32 

101001 

16 

8 

1010 

32 

32 

8 

1000 

Гб 

16 

оно 

32 

32 

32 

011001 

16 

32 

101011 

32 

32 

80 

111001 

16 

80 

011011 

32 

80 

80 

000101 

32 

8 

111011 

64 

64 

8 

100101 

32 

16 

000111 

64 

64 

80 

0100 

32 

32 

100111 

64 

80 

80 

010101 

32 

80 

010111 

80 

32 

80 

110101 

64 

8 

110111 

80 

64 

80 

001101 

64 

64 

001111 

80 

80 

8 




101111 

80 

80 

80 


9-429 
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Таблица 18.2. Содержимое поля формата команды 


Количество 

операндов 

Содержимое 
поля формата 

1 Значения, соответствующие 

операнду 1 

операнду 2 

операнду 3 

0 

Отсутствует 




1 

0 

АД1 



1 

1 

Стек 



2 

00 

АД1 

АД2 


2 

10 

» 

АД1 


2 

01 

» 



2 

011 

Стек 

АД1 


2 

111 

» 

Стек 


3 

0000 

АД1 

АД2 

АДЗ 

3 

1000 



АД2 

3 

0100 



АД1 

3 

1100 



Стек 

3 

0010 


Стек 

АД2 

3 

1110 


АД1 


3 

1010 

АД1 

Стек 

АД1 

3 

0001 

Стек 

АД1 


3 

оно 

АД1 

Стек 

Стек 

3 

1001 


АД1 


3 

0111 

Стек 1 

Стек 2 

АД1 

3 

0101 

Стек 2 

Стек 1 


3 

1011 

Стек 1 

Стек 2 

Стек 

3 

1101 

Стек 2 

Стек 1 


3 

ООП 

АД2 

АД1 

АДЗ 

3 

1111 


АД1 

Стек 


Обозначения. АД — адрес данных в оперативной памяти, «Стек» и «Стек 1»—дан¬ 
ные на вершине стека, «Стек 2» — данные, следующие за данными «Стек 1». 


ющихся к данным (содержимое поля класса команды равно 
001110 или 101110), то поле формата отсутствует. 

' Из табл. 18.2 следует, что содержимое поля формата может 
служить указателем и тех ситуаций, когда число обращений к 
данным меньше числа операндов команды, даже если стек не 
используется. Например, для команды с числом операндов, 
равным 2, и содержимым поля формата, равным 10, оба опе¬ 
ранда задаются содержимым одного и того же (единственного) 
поля адреса данных. В соответствии с этим для выполнения 
оператора присваивания А:=А+1 с целочисленным значени¬ 
ем А можно воспользоваться командой INCREMENT-INTEGER 
(с двумя операндами для исходного значения и для результа¬ 
та), задав в команде только один адрес данных (А). Таким об¬ 
разом, в системе іАРХ 432 проводится различие между числом 
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операндов команды и количеством адресов операндов, задавае¬ 
мых в команде. 

В следующем поле команды содержатся обращения к дан¬ 
ным (адреса для всех операндов, не находящихся в стеке опе¬ 
рандов) и адрес перехода (адрес команды). Общие принципы 
адресации операндов рассмотрены в гл. 17, поэтому здесь будет 
описан только способ их кодирования. При необходимости чи¬ 
татель может обратиться к рис. 17.7—17.9, на которых в форме 
графов древовидной структуры систематизированы все возмож¬ 
ные варианты адресов данных. 

На рис. 18.2 в так называемой нормальной бэкусовской 
форме приведены правила кодирования поля адресов данных и 
адреса перехода. Чтобы упростить подобную форму записи, из 
описания исключены взаимозависимости между отдельными 
элементами (например, в терме «скаляр» терм «смещение» 
должен иметь вид «смещение 16», если терм «тип длины поля 
смещения» равен 1). 

Следует обратить внимание, что в описании полей команды, 
приведенном на рис. 18.2, порядок их перечисления является 
противоположным изображенному на рис. 18.1. На рис. 18.1 по¬ 
ля в сегменте команды расположены по возрастанию адресов. 
Так, поле класса в команде имеет меньшее значение адреса, чем 
поле КОП. Однако с целью достижения соответствия с требо¬ 
ваниями спецификаций фирмы Intel для системы іАРХ 432 и 
общепринятым соглашением о расположении старших значащих 
битов в левой части поля представления в тексте на рис. 18.2 
для команд и их отдельных полей биты младших разрядов ад¬ 
реса размещены справа. При этом можно сказать, что процес¬ 
сор «просматривает» поля команд, начиная слева, т. е. с поля 
класса. 

В командах передачи управления задается адрес перехода, 
структура которого также отражена в бэкусовской записи 
(рис. 18.2). Поле адреса перехода содержит бит, значение ко¬ 
торого определяет, какая из двух форм представления адреса 
используется, а также 10-битовое смещение со знаком или 
16-битовое смещение без знака, указывающее команду, которой 
должно быть передано управление. Смещение со знаком, или 
относительное смещение, определяет положение адресуемой 
команды относительно адреса данной команды. Смещение без 
знака, или абсолютное смещение, задает положение адресуемой 
команды относительно начала сегмента команд. Значения сме¬ 
щений выражаются в битах, поскольку команды могут начи¬ 
наться с любого бита. Это объясняет, почему максимальная 
длина сегментов команд составляет 8192 байт. 

Для многих команд один или несколько операндов являются * 
объектами или дескрипторами доступа. Адресация к ним вы- 


9* 
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командаКОП [адресаопсрандов] [формат] класс 
адрсса_операндов •■= обращение_к_данным 

|обращенис_к.данным 
|обращенис_к.данным обращс:шс_кданным 
|обращенис_к_данным обращсшкмс_данным 
обращение_к данным 
|адрес_ііере\ода 

|обращение_к.данным адресперехода 
обращение_к_данным 15= адресскаляра 

I адрсс_элемента_записи 
I адрес_элемента_вектора 
I адрес_эл ем ента_в ектора_динамического_ги па 
адрес_скаляра "= смещение селектор_сегмента 

тип длины_поля_смещения 
ти і і_с ел е кто р а_с ег м ен та 09 

адрес_элемента записи "= косвенное_ііредставление_базы смещение 

селектор_сегмента тип_длины_поля_смещения 
типселектора_сегмента 01 

адресэлемента_вектора косвенное_представлениеиндекса база 

селектор_сегмента тип_длины_базы 
тип_селектора_сегмента 19 

адрес элемента_вектора_динамического типа I 5= косвенноепредставленис индекса 
косвенное_представление_базы селектор_сегмента 
типселекгора_сегмента I I 

тип_селектора_сегмента •’= 00 короткий прямой 

|01 длинный прямой 

110 косвенный посредством стека 

111 косвенный общего назначения 

селектор_сегмента "= селектор_короткий_прямой 

| сел ектор_дл инны й_іірямой 
I селектор_косвенны^посредством стека 
|селектор_косвенный_общего_назначения 
, селектор_короткий_прямой "= индекс ВСД_4 ВСД 2 

сепектор_длинный_прямой "= индекс_ВСД_14 ВСД_2 

селектор_косвенный_ 


посредст вом_стека 


не кодируется 


селектор_досвенный_общего_ 
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назначения "= смещение_7 ВСД2 индекс_ВСД_2 00 ВСД_2- 

|смещенис_7 ВСД_2 индекс_ВСД_6 01 ВСД_2 
|смещенис_16 ВСД_2 индекс_ВСД^ 1 О ВСД_2 
|смещение_16 ВСД_2 индекс_ВСД_6 11 ВСД2 
косвенныйиндекс І!= косвенное_представление_базы/индекса 

косвенная_баэа ::= косвенное_рредставление_базы/индекса 

косвенно^, представление. 

базы /индекса ; ;= і обращение к стеку 

базы/индекса 

Iсмещение тигущины_поля_смещения 10 внутрисегментное обращение 
к базе/ индексу 

Ісмещение селектор_сегмента_длинный/короткий 


длина_смещсния тип_сслектора_ссгменті_ 
длинного/короткого 00 

косвенное обращение к 
базе/индексу общего 
назначения 

тип селектора сегмента длин- 

ного/ короткого ..= 0 короткий_прямой_селектор, 

11 длинный_прямой селектор 

сслектор.ссгмента_длинный/ 

короткий ::= коротки й_прямойселектор 
|длинныіЦірямой_селектор 

тип_длины_поля_смещения 0 7-битовое смещение 

1 - 16-битовое смещение 


смещение 


”= смещение^ |смещени^6 


Тип_длины_базы 


база 

адресперехода 


::= 0 


И 

"= [смещение_1б] 

'.= относительный J 0 
|абсолютный_16 


нулевая длина (отсутствие) 
16-битовое смещение базы 


смещение_7 

смещение_16 

веху 

индекс_ВСД_2 
индекс_ВСД4 
индекс_ВСД_14 
относительный J0 
абсолютный_16 


7-битовое смещение без знака (в байтах) 
16-битовое смещение без знака (в байтах) 
2 бит селектора ВСД 
2 бит индексирования ДД в ВСД 
4 бит индексирования ДД в ВСД 
14 бит индексирования ДД в ВСД 
10-битовое смещение со знаком (в битах) 
16-битовое смещение без знака (в битах) 


Рис. 18.2. Синтаксис команды системы іАРХ 432. 
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полняется следующим образом. С помощью любой формы об¬ 
ращения к данным определяется адрес короткого порядкового 
числа как искомого операнда. Для извлечения этого числа (ад¬ 
ресации к нему) используется заданное смещение в соответст¬ 
вующем сегменте. Полученное число воспринимается как значе¬ 
ние длинного прямого селектора сегмента, т. е. как 14-битовый 
индекс дескриптора доступа (ДД) в ВСД и 2-битовый селек¬ 
тор ВСД. Если в соответствии с типом команды операнд явля¬ 
ется дескриптором доступа, этим операндом и будет ДД, опре¬ 
деленный этим селектором в виде короткого порядкового числа. 
Если же операндом является объект, он определяется указан¬ 
ным ДД. 

Специфика использования рассматриваемого формата команд 
заключается в том, что в соответствии со структурой этого фор¬ 
мата максимальное количество операндов равно трем. В то же 
время для некоторых команд, выполняющих операции над объ¬ 
ектами (это будет видно из следующего ниже описания), тре¬ 
буется большее число операндов. Например, операндами коман¬ 
ды CREATE-GENERIC-REFINEMENT являются объект «ре¬ 
сурсы памяти», два ДД и два коротких порядковых числа. Уве¬ 
личить фактическое число операндов удается следующим обра¬ 
зом. Согласно формату данной команды, для трех обращений 
к данным используется одно 16- и два 32-битовых поля. Шест¬ 
надцатибитовое поле предназначено для длинного прямого се¬ 
лектора сегмента объекта «ресурсы памяти». Первое из 32-бито¬ 
вых полей содержит два длинных прямых селектора сегментов 
для двух дескрипторов доступа, а во втором 32-битовом поле 
находятся два операнда — адреса двух коротких порядковых 
чисел. В нижеследующем описании команд такие подробности 
опускаются. 

Поле кода операции совместно с полем класса команды оп¬ 
ределяет тип выполняемой операции. В некоторых командах 
поле КОП отсутствует, поскольку в них тип операции однознач¬ 
но определяется содержимым поля класса (например, класс 
001110 определяет команду возврата, а класс 101110 — команду 
безусловной передачи управления). Длина поля КОП (если оно 
используется) может быть величиной от 1 до 5 бит. 

Рассмотрим пример кодирования команды. Пусть в 32-би- 
товом поле со смещением 1Е в сегменте данных контекста на¬ 
ходится значение переменной I, а в 32-битовом поле со смеще¬ 
нием 79 — значение переменной J. Из структуры объекта «кон¬ 
текст» (рис. 17.11) следует, что переменные I и J будут адресо¬ 
ваться посредством ВСД со значением 0 (BCD 0 —сегмент до¬ 
ступа к контексту) и индекса ВСД, равного 0 (ДД к сегменту 
данных контекста располагается в контексте со смещением 0). 
Рассмотрим команду ADD-INTEGER со значениями КОП и 
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класса соответственно 0101 и ОНО. (Команде этого класса, как 
следует из табл. 18.1, соответствует команда с тремя 32-бито- 
выми операндами.) 

Для выполнения операции I: = I+J команда должна быть 
закодирована в виде: 

0101 1111001 0000 00 О 00 00 0011110 0000 00 О 00 00 0100 оно 

КОП Обращение к данным 2 Обращение к данным 1 Формат Класс 

Согласно содержимому поля формата, поле обращения к 
данным 1 соответствует первому и третьему операндам, а по¬ 
ле обращения к данным 2 — второму операнду. В поле обра¬ 
щения к данным 1 справа налево закодирована следующая ин¬ 
формация: адрес скаляра (00), короткий прямой селектор сег¬ 
мента (00), тип 0 длины поля смещения, соответствующий 7-би¬ 
товому смещению, ВСД 0 (00), индекс ВСД — 0000 и величина 
смещения 1Е. 

Для суммирования значений двух верхних слов стека и за¬ 
грузки результата в поле переменной I следует воспользовать¬ 
ся командой 

0101 0011110 оооо оо о оо 00 0111 оно 

КОП Обращение к данным 1 Формат Класс 


КОМАНДЫ ОБЩЕГО НАЗНАЧЕНИЯ 

В этом и следующих разделах рассматриваются команды про¬ 
цессора общего назначения системы іАРХ 432. Порядок рас¬ 
смотрения в основном тот же, что и в гл. 15. Поскольку зна¬ 
чительное количество команд имеет много общего, при даль¬ 
нейшем рассмотрении они объединены в группы. После имени 
команды приводятся значения ее КОП и класса, например 
00..110001 или ..001001, если поле КОП отсутствует. 

Имя команды. MOVE-CHARACTER 00..110001 
Имя команды. MOVE-SHORT-ORDINAL 0000.. 1000 
Имя команды. MOVE-ORDINAL 000..0100 
Имя команды. MOVE-REAL 0..001101 
Имя команды. MOVE-TEMPORARY-REAL 00..100011 
Выполняемая операция. Содержимое 8-, 16-, 32-, 64- или 80-би¬ 
тового поля операнда — исходных данных копируется в поле 
операнда — результата. 

Количество операндов. 2 

Примечание. Операции над стеком — загрузка и извлечение 
данных — выполняются, если в поле формата в качестве одного 
из операндов указан стек. 
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Имя команды. SAVE-CHARACTER 11..011110 
Имя команды. SAVE-SHORT-ORDINAL 010..11111 
Имя команды. SAVE-ORDINAL 010..000001 
Имя команды. SAVE-REAL 1.. 100001 
Имя команды. SAVE-TEMPORARY-REAL 1..010001 
Выполняемая операция. 8-, 16-, 32-, 64- или 80-битовое содер¬ 
жимое вершины стека копируется в поле, адресуемое операн¬ 
дом команды. Состояние стека не изменяется. 

Количество операндов. 1 

Имя команды. ZERO-CHARACTER 0..011110 

Имя команды. ZERO-SHORT-ORDINAL 000..111110 

Имя команды. ZERO-ORDINAL 000..000001 

Имя команды. ZERO-REAL 0.. 100001 

Имя команды. ZERO-TEMPORARY-REAL 0..010001 

Выполняемая операция. Операнду длиной 8, 16, 32, 64 или 

80 бит присваивается значение, равное 0. 

Количество операндов. 1 

Имя команды. ONE-CHARACTER 01..011110 
Имя команды. ONE-SHORT-ORDINAL 100..111110 
Имя команды. ONE-ORDINAL 100..000001 
Выполняемая операция. Операнду длиной 8, 16 или 32 бит при¬ 
сваивается значение, равное +1. 

Количество операндов. 1 

Имя команды. CONVERT-CHARACTER-TO-SHORT-ORDINAL 
001001 

Имя команды. CONVERT-SHORT-ORDINAL-TO-CHARACTER 
Имя команды. 01.. 101001 

CONVERT-SHORT-ORDINAL-TO-ORDINAL 
00..011001 

Имя команды. CONVERT-SHORT-ORDINAL-TO-TEMPORARY- 
REAL 0..111001 

Имя команды. CONVERT-SHORT-INTEGER-TO-INTEGER 
10..011001 

Имя команды. CONVERT-SHORT-INTEGER-TO-TEMPORARY- 
REAL 1..111001 

Имя команды. CONVERT-ORDINAL-TO-SHORT-ORDINAL 
10..100101 

Имя команды. CONVERT-ORDINAL-TO-INTEGER 1110..0100 
Имя команды. CONVERT-ORDINAL-TO-TEMPORARY-REAL 
0..010101 

Имя команды. CONVERT-INTEGER-TO-SHORT-INTEGER 
01..100101 

Имя команды. CONVERT-INTEGER-TO-ORDINAL 1101..0100 
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Имя команды. CONVERT-INTEGER-TO-TEMPORARY-REAL 

01..010101 

Имя команды. CONVERT-SHORT-REAL-TO-TEMPORARY- 
REAL 11..010101 

Имя команды. CONVERT-REAL-TO-TEMPORARY-REAL 101101 
Имя команды. CONVERT-TEMPORARY-REAL-TO-ORDINAL 
0..11101 

Имя команды. CONVERT-TEMPORARY-REAL-TO-INTEGER 
01..111101 

Имя команды. CONVERT-TEMPORARY-REAL-TO-SHORT- 
REAL 11..111101 

Имя команды. CONVERT-TEMPORARY-REAL-TO-REAL 000011 
Выполняемая операция. Данные, адресуемые первым операн¬ 
дам команды, преобразуются в соответствии с форматом дан¬ 
ных, адресуемых вторым операндом, и размещаются на месте 
данных, адресуемых вторым операндом. 

Количество операндов. 2 

Если данные, адресуемые первым операндом команды, пред¬ 
ставлены в форме вещественного числа с плавающей точкой, 
а данные, адресуемые вторым операндом, имеют вид более ко¬ 
роткого вещественного числа с плавающей точкой или пред¬ 
ставляют собой данные другого типа, выполняется округление, 
тип которого определяется состоянием флага управления 
округлением в контексте. Если данные, адресуемые вторым 
операндом — порядковое или короткое порядковое число, зна¬ 
чение данных, адресуемых первым операндом, должно быть по¬ 
ложительным. При выполнении данной команды могут возник¬ 
нуть ошибки переполнения и антипереполнения. 

АРИФМЕТИЧЕСКИЕ КОМАНДЫ 

Имя команды. INCREMENT-CHARACTER 00I..1 10001 
Имя команды. INCREMENT-SHORT-ORDINAL 1100..1000 
Имя команды. INCREMENT-SHORT-INTEGER 1010..1000 
Имя команды. INCREMENT-ORDINAL 010..0100 
Имя команды. INCREMENT-INTEGER 0001..0100 
Выполняемая операция. Данные, адресуемые первым операн¬ 
дом команды, увеличиваются на 1 и пересылаются по адресу, 
указываемому вторым операндом. 

Количество операндов. 2 

Имя команды. DECREMENT-CHARACTER 101..110001 
Имя команды. DECREMENT-SHORT-ORDINAL 0010..1000 
Имя команды. DECREMENT-SHORT-INTEGER 0110..1000 
Имя команды. DECREMENT-ORDINAL 0110..0100 
Имя команды. DECREMENT-INTEGER 1001..0100 
Выполняемая операция. Данные, адресуемые первым операн- 
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дом команды, уменьшаются на 1 и пересылаются по адресу, 
указываемому вторым операндом. 

Количество операндов. 2 

Лмя команды. ADD-CHARACTER 001..01 ООП 
Лмя команды. ADD-SHORT-ORDINAL 0110..0010 
Имя команды. ADD-SHORT-INTEGER 01001..0010 
Имя команды. ADD-ORDINAL 1010..0110 
Имя команды. ADD-INTEGER 0101..0110 
Имя команды. ADD-SHORT-REAL-SHORT-REAL 00..101011 
Лмя команды. ADD-SHORT-REAL-TEMPORARY-REAL 
00..010111 

Имя команды. ADD-TEMPORARY-REAL-SHORT-REAL 

00..011011 

Имя команды. ADD-TEMPORARY-REAL 00..101111 
Имя команды. ADD-REAL-TEMPORARY-REAL 00..110111 
Имя команды. ADD-TEMPORARY-REAL-REAL 00..100111 
Имя команды. ADD-REAL-REAL 00..000111 
Выполняемая операция. Данные, адресуемые двумя операндами 
команды, складываются и результат помещается по адресу, за¬ 
даваемому третьим операндом. 

Количество операндов. 3 

Результатом выполнения всех команд над вещественными 
числами с плавающей точкой является длинное вещественное 
число с плавающей точкой. При формировании результата учи¬ 
тываются состояния флагов управления округлением и точно¬ 
стью в контексте. Некоторые команды над вещественными чис¬ 
лами с плавающей точкой допускают использование данных 
различной точности, адресуемых первыми двумя операндами 
команды. 

Имя команды. SUBTRACT-CHARACTER 101..010011 
Имя команды. SUBTRACT-SHORT-ORDINAL 01110..0010 
Имя команды. SUBTRACT-SHORT-INTEGER 11001..0010 
Имя команды. SUBTRACT-ORDINAL 0110..0110 
Имя команды. SUBTRACT-INTEGER 1101..0110 
Имя команды. SUBTRACT-SHORT-REAL-SHORT-REAL 

10..101011 

Имя команды. SUBTRACT-SHORT-REAL-TEMPORARY-REAL 

10..010111 

Имя команды. SUBTRACT-TEMPORARY-REAL-SHORT-REAL 

10..011011 

Имя команды. SUBTRACT-REAL-REAL 10..000111 
Имя команды. SUBTRACT-REAL-TEMPORARY-REAL 10.. 110111 
Имя команды. SUBTRACT-TEMPORARY-REAL-REAL 10..100111 
Имя команды. SUBTRACT-TEMPORARY-REAL 10..101111 
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Выполняемая операция. Данные, адресуемые первым операн¬ 
дом команды, вычитаются из данных, адресуемых вторым опе¬ 
рандом. Результат помещается по адресу, задаваемому треть¬ 
им операндом. 

Количество операндов. 3 

Результатом выполнения всех команд над вещественными 
числами с плавающей точкой является длинное вещественное 
число с плавающей точкой. При формировании результата учи¬ 
тываются состояние флагов управления округлением и точно¬ 
стью в контексте. Некоторые команды над вещественными чис¬ 
лами с плаващщей точкой допускают использование данных 
различной точности, адресуемых первыми двумя операндами 
команды. 

Имя команды. MULTIPLY-SHORT-ORDINAL 11110..0010 
Имя команды. MULTIPLY-SHORT-INTEGER 00101..0010 
Имя команды. MULTIPLY-ORDINAL 1110..0110 
Имя команды. MULTIPLY-INTEGER 0011..0110 
Имя команды. MULTIPLY-SHORT-REAL-SHORT-REAL 
00..010111 

Имя команды. MULTIPLY-SHORT-REAL-TEMPORARY-REAL 
01..010111 

Имя команды. MULTIPLY-TEMPORARY-REAL-SHORT-REAL 
01..101011 

Имя команды. MULTIPLY-REAL-REAL 01..000111 
Имя команды. MULTIPLY-REAL-TEMPORARY-REAL 01..110111 
Имя команды. MULTIPLY-TEMPORARY-REAL-REAL 01..100111 
Имя команды. MULTIPLY-TEMPORARY-REAL 01..101111 
Выполняемая операция. Результат умножения данных, адресуе¬ 
мых первыми двумя операндами команды, помещается по адре¬ 
су, задаваемому третьим операндом. 

Количество операндов. 3 

Если перемножаются не вещественные числа, то по адресу 
третьего операнда помещаются младшие 16 или 32 бит резуль¬ 
тата. При выполнении данной команды переполнения не бы¬ 
вает. Результатом выполнения всех команд над вещественны¬ 
ми числами с плавающей точкой является длинное веществен¬ 
ное число с плавающей точкой. При формировании результа¬ 
та учитываются состояния флагов управления округлением и 
точностью в контексте. Некоторые команды над вещественными 
числами с плавающей точкой допускают использование данных 
разной точности, адресуемых первыми двумя операндами 
команды. 

Имя команды. DIVIDE-SHORT-ORDINAL 00001..0010 
Имя команды. DIVIDE-SHORT-INTEGER 10101..0010 
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Имя команды. DIVIDE-ORDINAL 0001..0110 
Имя команды. DIVIDE-INTEGER 1011..0110 
Имя команды. DIVIDE-SHORT-REAL-SHORT-REAL 11..101011 
Имя команды. DIVIDE-SHORT-REAL-TEMPORARY-REAL 
11..010111 

Имя команды. DIVIDE-TEMPORARY-REAL-SHORT-REAL 

11..011011 

Имя команды. DIVIDE-REAL-REAL 11..000111 
Имя команды. DIVIDE-TEMPORARY-REAL-REAL 11..100111 
Имя команды. DIVIDE-TEMPORARY-REAL 011..101111 
Имя,команды. DIVIDE-REAL-TEMPORARY-REAL 11..110111 
Выполняемая операция. Производится деление данных, адре¬ 
суемых вторым операндом команды, на данные, адресуемые 
первым операндом; результат помещается по адресу, задавае¬ 
мому третьим операндом команды. 

Количество операндов. 3 

Если операция выполняется не над вещественными числами 
с плавающей точкой и делимое не является числом, кратным 
делителю, результат усекается с округлением в сторону нуля. 
Б результате выполнения всех команд над вещественными чис¬ 
лами с плавающей точкой получается длинное вещественное 
число с плавающей точкой. При формировании результата учи¬ 
тываются состояния флагов управления округлением и точно¬ 
стью в контексте. Некоторые команды над вещественными чис¬ 
лами с плавающей точкой допускают использование данных 
различной точности, адресуемых первыми двумя операндами 
команды. 

Имя команды. REMAINDER-SHORT-ORDINAL 10001..0010 
Имя команды. REMAINDER-SH0RT4NTEGER 01101..0010 
Имя команды. REMAINDER-ORDINAL 1001..0110 
Имя команды. REMAINDER-INTEGER 0111. 0110 
Имя команды. REMAINDER-TEMPORARY-REAL 10..100011 
Выполняемая операция. Производится деление данных, адресуе¬ 
мых вторым операндом команды, на данные, адресуемые пер¬ 
вым операндом; остаток помещается по адресу, задаваемому 
третьим операндом. 

Количество операндов. 3 

Для данных типа целое число или короткое целое число со 
знаком знак остатка совпадает со знаком делимого. В случае 
длинных вещественных чисел с плавающей точкой деление вы¬ 
полняется по итеративному алгоритму до заданного числа ша¬ 
гов или до получения частичного остатка, абсолютная величи¬ 
на которого не превышает величины делителя. В последнем слу¬ 
чае частичный остаток является истинным результатом. При 
формировании результата учитываются состояния флагов 
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управления округлением и точностью в контексте. Если же ча¬ 
стичный остаток не является еще истинным результатом, округ¬ 
ление и установление требуемой точности не выполняются. Знак 
результата совпадает со знаком делимого. 

Имя команды. ABSOLUTE-VALUE-SHORT-REAL 1011..0100 
Имя команды. ABSOLUTE-VALUE-REAL 11..001101 
Имя команды. ABSOLUTE-VALUE-TEMPORARY-REAL 
11..100011 

Выполняемая операция. Абсолютное значение данных, адресуе¬ 
мых первым операндом команды, помещается по адресу, зада¬ 
ваемому вторым операндом. 

Количество операндов. 2 

Имя команды. NEGATE-SHORT-INTEGER 1110..1000 
Имя команды. NEGATE-INTEGER 0101..0100 
Имя команды. NEGATE-SHORT-REAL 0011..0100 
Имя команды. NEGATE-REAL 10..100011 
Имя команды. NEGATE-TEMPORARY-REAL 10..100011 
Выполняемая операция. Данные, адресуемые первым операн¬ 
дом команды, с противоположным знаком помещаются по ад¬ 
ресу, задаваемому вторым операндом. 

Количество операндов. 2 

Имя команды. SQUARE-ROOT-TEMPORARY-REAL 01..100011 
Выполняемая операция. Из данных, адресуемых первым опе¬ 
рандом команды, извлекается квадратный корень и помещается 
по адресу, задаваемому вторым операндом. 

Количество операндов. 2 

При формировании результата учитываются состояния фла¬ 
гов управления округлением и точностью в контексте. 

КОМАНДЫ СРАВНЕНИЯ 

Имя команды. EQUAL-CHARACTER 0011..010011 
Имя команды. EQUAL-SHORT-ORDINAL 000..1100 
Имя команды. EQUAL-ORDINAL 000.. 1010 
Имя команды. EQUAL-SHORT-REAL 011..1010 
Имя команды. EQUAL-REAL 0..111011 
Имя команды. EQUAL-TEMPORARY-REAL 0..001111 
Выполняемая-операция. Производится сравнение данных, адре¬ 
суемых первыми двумя операндами команды. Результат сравне¬ 
ния в виде логического значения (систинно» — при равенстве 
сравниваемых данных и «ложно> — в противоположном слу¬ 
чае) помещается по адресу, задаваемому операндом. 
Количество операндов. 3 
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Третий операнд адресует 1 байт символьных данных. 
Примечание. Сравнение целых чисел и коротких целых чисел 
может выполняться с помощью команд для порядковых и корот¬ 
ких порядковых чисел. 

Имя команды. EQUAL-ZERO-CHARACTER 011..110001 
Имя команды. EQUAL-ZERO-SHORT-ORDINAL 00..101001 
Имя команды. EQUAL-ZERO-ORDINAL 00..000101 
Имя команды. EQUAL-ZERO-SHORT-REAL 101..000101 
Имя команды. EQUAL-ZERO-REAL 0.. 110101 
Имя команды. EQUAL-ZERO-TEMPORARY-REAL 0..011101 
Выполняемая операция. Производится сравнение данных, адре¬ 
суемых первым операндом команды с нулем. Результат срав¬ 
нения в виде логического значения («истинно» — при равенстве 
данных нулю и «ложно» — в противоположном случае) поме¬ 
щается по адресу, задаваемому вторым операндом команды. 
Количество операндов. 2 

Второй операнд адресует 1 байт символьных данных. 

Имя команды. NOT-EQUAL-CHARACTER 1011..010011 
Имя команды. NOT-EQUAL-SHORT-ORDINAL 100..1100 
Имя команды. NOT-EQUAL-ORDINAL 100..1010 
Выполняемая операция. Производится сравнение данных, адре¬ 
суемых первыми двумя операндами команды. Результат срав¬ 
нения в виде логического значения («истинно» —при неравен¬ 
стве данных и «ложно» — в противоположном случае) помеща¬ 
ется по адресу, задаваемому третьим операндом. 

Количество операндов. 3 

Третий операнд адресует 1 байт символьных данных. 

Имя команды. NOT-EQUAL-ZERO-CHARACTER 111..110001 
Имя команды. NOT-EQUAL-ZERO-SHORT-ORDINAL 
10..101001 

Имя команды. NOT-EQUAL-ZERO-ORDINAL 010..000101 
Имя команды. NOT-EQUAL-ZERO-SHORT-REAL 101..000101 
Имя команды. NOT-EQUAL-ZERO-REAL 0..110*101 
Имя команды. NOT-EQUAL-ZERO-TEMPORARY-REAL 
0..011101 

Выполняемая операция. Производится сравнение данных, адре¬ 
суемых первым операндом команды, с нулем. Результат срав¬ 
нения в виде логического значения («истинно» — при неравенст¬ 
ве нулю и «ложно» — в противоположном случае) помещается 
по адресу, задаваемому вторым операндом. 

Количество операндов. 2 

Второй операнд адресует 1 байт символьных данных. 
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Имя команды. GREATER-THAN-CHARACTER 0111..010011 
Имя команды. GREATER-THAN-SHORT-ORDINAL 010..1100 
Имя команды. GREATER-THAN-SHORT-INTEGER 001..1100 
Имя команды. GREATER-THAN-ORDINAL 010..1010 
Имя команды. GREATER-THAN-INTEGER 001..1010 
Имя команды. GREATER-THAN-SHORT-REAL 0111..1010 
Имя команды. GREATER-THAN-REAL 01..111011 
Имя команды. GREATER-THAN-TEMPORARY- REAL 01..001111 
Выполняемая операция. Если значение данных, адресуемых вто¬ 
рым операндом команды, больше значения данных, адресуемых 
первым операндом, то по адресу, задаваемому третьим операн¬ 
дом, помещается логическое значение «истинно». В противном 
случае по адресу, задаваемому третьим операндом, располага¬ 
ется логическое значение «ложно». 

Количество операндов. 3 

Третий операнд адресует 1 байт символьных данных. 

Имя команды. GREATER-THAN-OR-EQUAL-CHARACTER 

1111..010011 

Имя команды. GREATER-THAN-OR-EQUAL-SHORT-ORDINAL 

110..1100 

Имя команды. GREATER-THAN-OR-EQUAL-SHORT-INTEGER 

101..1100 

Имя команды. GREATER-THAN-OR-EQUAL-ORDINAL 

110..1010 

Имя команды. GREATER-THAN-OR-EQUAL-INTEGER 101..1010 
Имя команды. GREATER-THAN-OR-EQUAL-SHORT-REAL 

1111..1010 

Имя команды. GREATER-THAN-OR-EQUAL-REAL 11..111011 
Имя команды. GREATER-THAN-OR-EQUAL-TEMPORARY- 
REAL 11..001111 

Выполняемая операция. Если значение данных, адресуемых 
вторым операндом команды, больше или равно значению дан¬ 
ных, адресуемых первым операндом, то по адресу, задаваемому 
третьим операндом, помещается логическое значение «истинно». 
В противном случае по адресу, задаваемому третьим операндом, 
располагается логическое значение «ложно». 

Количество операндов. 3 

Третий операнд адресует 1 байт символьных данных. 

Имя команды. POSITIVE-SHORT-INTEGER 011..101001 

Имя команды. POSITIVE-INTEGER 110..000101 

Имя команды. POSITIVE-SHORT-REAL 011..000101 

Имя команды. POSITIVE-REAL 01..110101 

Имя команды. POSITIVE-TEMPORARY-REAL 01..011101 

Выполняемая операция. Если данные, адресуемые первым one- 
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рандом команды, больше нуля, то .по адресу, задаваемому вто¬ 
рым операндом, помещается логическое значение «истинно. 
В противном случае по адресу, задаваемому вторым операн¬ 
дом, располагается логическое значение «ложно». 

Количество операндов. 2 

Второй операнд адресует 1 байт символьных данных. 
Примечание. Применительно к этой команде нуль не интерпре¬ 
тируется как положительное число. 

Имя команды. NEGATIVE-SHORT-INTEGER 111..101001 
Имя команды. NEGATIVE-INTEGER 00I..000101 
Имя команды. NEGATIVE-SHORT-REAL 111..000101 
Имя команды. NEGATIVE-REAL 11..110101 
Имя команды. NEGATIVE-TEMPORARY-REAL 11..011101 
Выполняемая операция. Если значение данных, адресуемых 
первым операндом команды, меньше нуля, то по адресу, зада¬ 
ваемому вторым операндом, помещается логическое значение 
«истинно», в противном случае — значение «ложно». 

Количество операндов. 2 

Второй операнд адресует 1 байт символьных данных. 

ЛОГИЧЕСКИЕ КОМАНДЫ 

Имя команды. AND-CHARACTER 001..010011 
Имя команды. AND-SHORT-ORDINAL 0000..0010 
Имя команды. AND-ORDINAL 000..0110 

Выполняемая операция. Над данными, адресуемыми первыми 
двумя операндами команды, поразрядно выполняется логиче¬ 
ская операция конъюнкции (И). Результат помещается по ад¬ 
ресу, задаваемому третьим операндом. 

Количество операндов. 3 

Имя команды. OR-CHARACTER 100..010011 
Имя команды. OR-SHORT-ORDINAL 1000..0010 
Имя команды. OR-ORDINAL 0100..0110 

Выполняемая операция. Над данными, адресуемыми первыми 
двумя операндами команды, поразрядно выполняется логиче¬ 
ская операция дизъюнкции (ИЛИ). Результат помещается по 
адресу, задаваемому третьим операндом. 

Количество операндов. 3 

Имя команды. XOR-CHARACTER 010..010011 
Имя команды. XOR-SHORT-ORDINAL 0100..0010 
Имя команды. XOR-ORDINAL 1100..0110 

Выполняемая операция. Над данными, адресуемыми первыми 
двумя операндами команды, поразрядно выполняется логиче- 
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ская операция ИСКЛЮЧАЮЩЕЕ ИЛИ. Результат помещается 
по адресу, задаваемому третьим операндом. 

Количество операндов. 3 

Имя команды. XNOR-CHARACTER 110..010011 
Имя команды. XNOR-SHORT-ORDINAL 1100..0010 
Имя команды. XNOR-ORDINAL 0010..0110 

Выполняемая операция. Над данными, адресуемыми первым» 
двумя операндами команды, поразрядно выполняется логиче¬ 
ская операция НЕ-ИСКЛЮЧАЮЩЕЕ ИЛИ. Результат поме¬ 
щается по адресу, задаваемому третьим операндом. 

Количество операндов. 3 

Имя команды. COMPLEMENT-CHARACTER 10..110001 
Имя команды. COMPLEMENT-SHORT-ORDINAL 1000..1000 
Имя команды. COMPLEMENT-ORDINAL 100..0100 
Выполняемая операция. Над данными, адресуемыми первым 
операндом команды, поразрядно выполняется логическая опера¬ 
ция НЕ (отрицание). Результат помещается по адресу, зада¬ 
ваемому вторым операндом. 

Количество операндов. 2 

Имя команды. EXTRACT-SHORT-ORDINAL 0010..0010 
Имя команды. EXTRACT-ORDINAL 00..001011 
Выполняемая операция. Из кода данных, адресуемых вторым 
операндом команды, извлекается строка последовательно рас¬ 
положенных битов и помещается (с выравниванием по правой 
границе) по адресу, задаваемому третьим операндом. 
Количество операндов. 3 

Данные, адресуемые первым операндом команды, являются 
коротким порядковым числом. Наименьший значащий байт 
представления этого числа определяет порядковый номер пер¬ 
вого бита извлекаемой последовательности битов. В зависимо¬ 
сти от того, являются ли данные, адресуемые вторым и треть¬ 
им операндами, порядковыми или короткими порядковыми чис¬ 
лами, используются только младшие 4 или 5 бит этого байта. 
Порядковый номер первого бита извлекаемой последовательно¬ 
сти определяет наименьший значащий бит этой последователь¬ 
ности, а также указывает его положение в виде смещения (по 
числу разрядов) от наименьшего значащего бита данных, ад¬ 
ресуемых вторым операндом. Значение старшего байта опреде¬ 
ляет уменьшенное на единицу число битов извлекаемой по¬ 
следовательности. С помощью указанных 2 байт может опреде¬ 
ляться последовательность, образующаяся многократным цик¬ 
лическим копированием (слева направо) битов данных, адре¬ 
суемых вторым операндом. 


10-429 
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Данные, адресуемые вторым операндом команды, являются 
порядковым или коротким порядковым числом, из которого из¬ 
влекается последовательность битов. Выделенная последова¬ 
тельность помещается по адресу, задаваемому третьим операн¬ 
дом, который определяет порядковое или короткое порядковое 
число. Помещаемая последовательность выравнивается по пра¬ 
вой границе поля с заполнением его свободной части ведущими 
нулями. 

Имя команды. INSERT-SHORT-ORDINAL 1010..0010 
.Имя команды. INSERT-ORDINAL 10..001011 
Выполняемая операция. Из двоичного кода данных, адресуе¬ 
мых вторым операндом команды, извлекается строка последо¬ 
вательно расположенных битов (начиная с младшего разряда 
■справа) и помещается в область, задаваемую третьим операн¬ 
дом. 

Количество операндов. 3 

Эти команды выполняются подобно командам EXTRACT, 
за исключением того, что первый операнд наряду с длиной оп¬ 
ределяет и позицию начала размещения пересылаемой после¬ 
довательности в области, адресуемой третьим операндом 
команды. 

Примечание. Существуют разновидности этих команд для неде¬ 
лимого выполнения операций 0 . 

Имя команды. SIGNIFICANT-BIT-SHORT-ORDINAL 
0100..1000 

Имя команды. SIGNIFICANT-BIT-ORDINAL 00..100101 
Выполняемая операция. Определяется положение старшего би¬ 
та в двоичном коде данных, адресуемых первым операндом 
команды. Порядковый номер этого разряда помещается по 
адресу, задаваемому вторым операндом. 

Количество операндов. 2 

Данные, адресуемые первым операндом команды, представ¬ 
ляют собой порядковое или короткое порядковое число; дан¬ 
ные, адресуемые вторым операндом — короткое порядковое 
число. 

КОМАНДЫ ПЕРЕДАЧИ УПРАВЛЕНИЯ 

Имя команды. CALL-CONTEXT 101..000001 

Выполняемая операция. Выполнение команд текущего контекста 

приостанавливается. Создается объект «контекст»; управление 

’> Эти разновидности не включены в данное описание. Особенности неде¬ 
лимого выполнения команд, т. е. выполнения без прерывания, обсуждаются 
в гл. 17 и далее на примере команд сложения порядковых и коротких поряд¬ 
ковых чисел (см., например, команду INDIVISIBLY-ADD-SHORT-ORDI- 
NAL) . — Прим, перев. 
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передается определенному сегменту команд, адресуемому через; 
задаваемый домен. 

Количество операндов. 2 

Первый операнд команты адресуется к дескриптору доступа к. 
объекту «домен». Второй операнд—адрес короткого порядково¬ 
го числа, которое используется в качестве индекса для нахож¬ 
дения дескриптора к сегменту команд в выделенном домене. 

Имя команды. CALL-CONTEXT-WITH-MESSAGE 111..100101 
Выполняемая операция. Выполнение команд текущего контекста-, 
приостанавливается. Создается новый объект «контекст». В со¬ 
зданный контекст помещается дескриптор доступа к специаль¬ 
но указываемому объекту. Управление передается определенно¬ 
му сегменту команд, адресуемому через задаваемый домен. 
количество операндов. 3 

Первым операндом является дескриптор доступа к объекту 
«домен». Второй операнд — короткое порядковое число, ис¬ 
пользуемое в качестве индекса для нахождения дескриптора- 
доступа к сегменту команд в выделенном домене. Третий опе¬ 
ранд— дескриптор доступа, поставляемый в новый контекст,, 
т- е. дескриптор доступа к объекту «сообщение». 

Имя команды. RETURN ..001110 

Выполняемая операция. Уничтожается текущий объект «кон¬ 
текст», а также все объекты, имеющие в таблице объектов 
процесса номера уровня больше или равные номеру уровня 
данного контекста. Управление передается команде, адресуе¬ 
мой посредством указателя команд в контексте, определяемом- 
содержимым поля «дескриптор доступа предыдущего контек¬ 
ста» в уничтожаемом контексте. 

Количество операндов. 0 

Примечание. При выполнении команды обновляется содержи¬ 
мое дескриптора блока памяти для текущего процесса, что обес¬ 
печивает своевременную регистрацию освобождаемой памяти. 

Имя команды. BRANCH ..101110 

Выполняемая операция. Управление передается определенной 
команде в пределах данного сегмента команд. 

Количество операндов. 1 (адрес перехода). 

Имя команды. BRANCH-INDIRECT 001..111110 
Выполняемая операция. Управление передается команде в пре¬ 
делах данного сегмента команд, смещение которой в битах за¬ 
дается значением операнда в форме короткого порядкового* 
числа. 

Количество операндов. 1 


Ю* 
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Имя команды. BRANCH-INTERSEGMENT 110..000001 
Выполняемая операция. Управление передается заданной коман¬ 
де в указанном сегменте команд. 

Количество операндов. I 

Поле длиной 32 бит, адресуемое операндом, используется для 
записи двух коротких порядковых чисел. Первое из этих чи¬ 
сел—индекс в домене, связанном с текущим контекстом. Этот 
индекс определяет дескриптор доступа к сегменту команд. Вто¬ 
рое число задает (в битах) смещение команды. 

Имя команды. BRANCH-INTERSEGMENT-WITHOUT-TRAQE 

001..000001 

Выполняемая операция. Производятся те же действия, что и по 
команде BRANCH-INTERSEGMENT с тем отличием, что в дан¬ 
ном случае ошибки трассировки на выполнение команды не 
влияют. 

Количество операндов. 1 

Имя команды. BRANCH-INTERSEGMENT-AND-UNK 1111..0100 
Выполняемая операция. По адресу, задаваемому вторым опе¬ 
рандом, формируется адрес следующей команды. Управление 
передается определенной команде в указанном сегменте 
команд. 

Количество операндов. 2 

Содержимое 32-битовых полей, адресуемых операндами 
.команды, воспринимается как четыре коротких порядковых 
числа. Первое используется в качестве индекса в домене, свя¬ 
занном с текущим контекстом. Посредством этого индекса оп¬ 
ределяется дескриптор доступа к сегменту команд. Второе чис¬ 
ло определяет смещение (в битах) команды в сегменте. Третье 
число определяет индекс текущего сегмента команд в домене, 
четвертое — смещение в битах для команды, непосредственно 
следующей за данной. 

Имя команды. BRANCH-TRUE 0..0000 

Выполняемая операция. Если операнд типа «символьные дан¬ 
ные» принимает логическое значение «истинно», управление 
передается адресуемой команде в пределах данного сегмента 
команд. В противном случае управление передается следующей 
команде. 

Количество операндов. 2 (короткое порядковое число и адрес 
перехода). 

Имя команды. BRANCH-FALSE 0..0000 

Выполняемая операция. Если операнд типа «символьные дан¬ 
ные» принимает логическое значение «ложно», управление пе- 
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редается адресуемой команде в данном сегменте команд. 
В противном случае управление передается следующей команде. 
Количество операндов. 2 (короткое порядковое число и адрес 
перехода). 

Имя команды. SET-CONTEXT-MODE 011..111110 
Выполняемая операция. В поле текущего объекта «контекст», 
определяющее состояние контекста, помещается содержимое 
поля, адресуемого операндом (короткое порядковое число). 
Количество операндов. 1 

Примечание. Эта операция позволяет изменять значение флага 
управления обработкой неточных результатов, флага задания 
точности и флагов управления округлением и обработкой оши¬ 
бок в контексте. 

КОМАНДЫ АДРЕСАЦИИ 

Имя команды. CREATE-DATA-SEGMENT 10011..0010 
Выполняемая операция. Распределяется память для сегмента 
данных требуемой длины. Эта память выделяется либо из ука¬ 
зываемого объекта «ресурсы памяти», либо из локальных ре¬ 
сурсов памяти текущего процесса. В таблицу объектов вносит¬ 
ся соответствующий дескриптор объекта. При обращении за 
памятью в объект «ресурсы памяти» запись вносится в табли¬ 
цу объектов, связанную с объектом «ресурсы памяти», в про¬ 
тивном случае — в таблицу объектов, связанную с текущим 
процессом. Дескриптор доступа к сегменту сохраняется в ука¬ 
зываемом сегменте доступа. 

Количество операндов. 3 

Первый операнд — короткое порядковое число, определяю¬ 
щее в байтах длину сегмента. Второй операнд — адрес объекта 
«ресурсы памяти» или адрес локальных ресурсов памяти дан¬ 
ного процесса, если селектор объекта равен нулю. В третьем 
операнде задается адрес дескриптора доступа к формируемому 
сегменту памяти. В этом дескрипторе флаги прав записи и чте¬ 
ния устанавливаются в 1, флаги прав удаления устанавлива¬ 
ются в 0, а состояние хип-флага зависит от вида второго опе¬ 
ранда. 

Примечание. При выполнении всех команд, производящих за¬ 
пись в сегмент доступа, возникает ошибка типа «стирание 
дескриптора доступа, флаги удаления которых не сброшены», 
если в соответствующем поле сегмента доступа находился дес¬ 
криптор доступа с установленными флагами удаления. 

Имя команды. CREATE-ACCESS-SEGMENT 01011..0010 
Выполняемая операция. Распределяется память для сегмента 
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доступа требуемого размера. Эта память выделяется либо из 
указываемого объекта «ресурсы памяти», либо из локальных 
ресурсов памяти текущего процесса. В таблицу объектов вно¬ 
сится соответствующий дескриптор объекта. При обращении 
за памятью в объект «ресурсы памяти» запись вносится в таб¬ 
лицу объектов, связанную с объектом «ресурсы памяти», в про¬ 
тивном случае — в таблицу объектов, связанную с текущим про¬ 
цессом. Дескриптор доступа к сегменту сохраняется в заданном 
сегменте доступа. 

Количество операндов. См. описание команды CREATE-DATA- 
SEGMENT. 

Имя команды. CREATE-TYPED-SEGMENT 01..110011 
Выполняемая операция. Формируется сегмент, тип которого 
определяется в объекте «управление дескриптором». Память 
выделяется из указываемого объекта «ресурсы памяти» либо из. 
локальных ресурсов памяти текущего процесса. В таблицу объ¬ 
ектов вносится соответствующий дескриптор объекта. При об¬ 
ращении за памятью в объект «ресурсы памяти» запись вносит¬ 
ся в таблицу объектов, связанную с объектом «ресурсы памя¬ 
ти», в противном случае — в таблицу объектов, связанную с те¬ 
кущим процессом. Дескриптор доступа к сегменту сохраняете» 
в заданном сегменте доступа. 

Количество операндов. 4 

Первый, второй и третий операнды такие же, как и в коман¬ 
де CREATE-DATA-SEGMENT. В дескрипторе доступа устанав¬ 
ливаются все системные права доступа к сегменту. Четвертый? 
операнд содержит обращение к объекту «управление дескрипто¬ 
ром». 

Имя команды. CREATE-GENERIC-REFINEMENT 01..001011 
Выполняемая операция. В таблице объектов создается дескрип¬ 
тор аффинажа, содержащий описание части сегмента. Инфор¬ 
мация о типе для части сегмента идентична соответствующей 
информации для сегмента в целом. Дескриптор доступа к аф¬ 
финажу запоминается в заданном сегменте доступа. 

Количество операндов. 5 

Первый операнд указывает адрес объекта «ресурсы памяти»- 
или локальных ресурсов памяти текущего процесса, чем опре¬ 
деляется используемая таблица объектов. Второй операнд, 
задает положение дескриптора доступа к аффинажу. Третьим 
операндом является селектор дескриптора доступа к сегменту. 
Четвертый операнд представляет собой короткое порядковое 
число, определяющее длину аффинажа (части сегмента). Пятый 
операнд — короткое порядковое число, задающее смещение аф¬ 
финажа в сегменте. 
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Имя команды. CREATE-TYPED-REFINEMENT 1111..0110 
Выполняемая операция. В таблице объектов создается дескрип¬ 
тор аффинажа, содержащий описание части сегмента. Значение 
базового типа в дескрипторе такое же, как и у всего сегмен¬ 
та, а значение системного типа определяется объектом «управ¬ 
ления аффинажем». Дескриптор доступа к аффинажу запоми¬ 
нается в указываемом сегменте доступа. 

Количество операндов. 6 

Первый операнд является адресом объекта «управление аф¬ 
финажем». Остальные операнды идентичны операндам коман¬ 
ды CREATE-GENERIC-REFINEMENT. 

Имя команды. CREATE-PRIVATE-TYPE 00..110011 
Выполняемая операция. В таблице объектов создается дескрип¬ 
тор типа, устанавливающий связь между объектом и объектом 
«определение типа». Дескриптор доступа к дескриптору типа 
(объекту расширенного типа) сохраняется в указываемом сег¬ 
менте доступа. 

Количество операндов. 4 

Первый операнд является адресом объекта «определение ти¬ 
па». Остальные три операнда совпадают с первыми тремя опе¬ 
рандами команды CREATE-GENERIC-REFINEMENT. 

Имя команды. CREATE-PUBLIC-TYPE 10..110011 
Выполняемая операция. Производятся те же действия, что и по 
команде CREATE-PRIVATE-TYPE, однако дескриптор доступа 
помечается как «общий», а не «частный». 

Количество операндов. 4 

Имя команды. CREATE-ACCESS-DESCRIPTOR 110011..0010 
Выполняемая операция. В указываемый сегмент доступа поме¬ 
щается дескриптор доступа к определенному дескриптору в таб¬ 
лице объектов. 

Количество операндов. 3 

Первый операнд является адресом таблицы объектов, вто¬ 
рой — адресом короткого порядкового числа, используемого как 
индекс для таблицы объектов. Третий операнд представляет со¬ 
бой адрес сегмента доступа, куда будет помещен сформирован¬ 
ный дескриптор доступа. 

Примечание. Данная команда формирует потенциальный адрес к 
существующему сегменту. Для ее успешного выполнения необ¬ 
ходимо иметь дескриптор доступа к таблице объектов с соот¬ 
ветствующими правами доступа. 

Имя команды. RETRIEVE-PUBLIC-TYPE-REPRESENTATION 

0101..1000 
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Выполняемая функция. В указанный сегмент доступа помеща¬ 
ется дескриптор доступа к объекту расширенного типа (адре¬ 
суемому через дескриптор типа) при условии, что этот объект 
определен как объект общего пользования. 

Количество операндов. 2 

Первый операнд является селектором дескриптора доступа 
к объекту как объекту расширенного типа, т. е. дескриптора 
доступа, ссылающегося на дескриптор типа. Вторым операндом 
служит селектор дескриптора доступа к сегменту доступа, куда 
должен быть помещен результат. 

Имя команды. RETRIEVE-TYPE-REPRESENTATION 
11I01..0010 

Выполняемая функция. В указанный сегмент доступа помеща¬ 
ется дескриптор доступа к объекту расширенного типа. 
Количество операндов. 3 

Первый операнд является селектором дескриптора доступа 
к объекту как объекту расширенного типа, т. е. дескриптора до¬ 
ступа, ссылающегося на дескриптор типа. Вторым операндом 
служит селектор дескриптора доступа к объекту «определение 
типа». Третий операнд — селектор дескриптора доступа к сег¬ 
менту доступа, куда будет помещен результат. Система регист¬ 
рирует ошибку, если адресуемый объект «определение типа» от¬ 
личается от указываемого объекта расширенного типа. 

Имя команды. RETRIEVE-TYPE-DEFINITION 1101..1000 
Выполняемая операция. В указанный сегмент доступа помеща¬ 
ется дескриптор доступа к объекту «определение типа», связан¬ 
ному с заданным дескриптором типа. 

Количество операндов. 2 

Первый операнд является селектором дескриптора доступа 
к объекту расширенного типа, т. е. дескриптора доступа, ссыла¬ 
ющегося на дескриптор типа. Второй операнд представляет со¬ 
бой селектор дескриптора доступа к сегменту доступа, куда 
должен быть помещен результат. 

Примечание. В первом ДД должны быть определены системные 
права на выполнение этой операции. 

Имя команды. RETRIEVE-REFINED-OBJECT 00011..00I0 
Выполняемая операция. В указанный сегмент доступа помеща¬ 
ется дескриптор доступа к сегменту, которому принадлежит ад¬ 
ресуемый аффинаж. 

Количество операндов. 3 

Первый операнд является селектором дескриптора доступа к 
объекту «управление аффинажем». Второй операнд представ- 
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ляет собой селектор дескриптора доступа к аффинажу, а тре¬ 
тий— селектор дескриптора доступа к сегменту доступа, куда 
должен быть помещен результат. 

Имя команды. ENTER-ACCESS-SEGMENT 0111..1000 
Выполняемая операция. Формируется значение ВСД текущего 
контекста, равное значению адресуемого сегмента доступа. 
Количество операндов. 2 

Первый операнд является селектором дескриптора доступа к 
сегменту доступа. Второй операнд представляет собой корот¬ 
кое порядковое число, принимающее значение 1, 2 или 3. Зна¬ 
чение дескриптора доступа, адресуемого первым операндом, 
помещается в объект «контекст» в позицию ВСД с номером, 
определяемым вторым операндом. 

Имя команды. ENTER-GLOBAL-ACCESS-SEGMENT 101..111110 
Выполняемая операция. Сегмент доступа, адресуемый третьим 
дескриптором доступа в сегменте доступа процесса, назначает¬ 
ся в качестве ВСД текущего контекста. 

Количество операндов. 1 

Операнд адресует короткое порядковое число, как в коман¬ 
де ENTER-ACCESS-SEGMENT 

Имя команды. COPY-ACCESS-DESCRIPTOR 0001..1000 
Выполняемая операция. Значение дескриптора доступа, адре¬ 
суемого первым операндом, переносится в качестве значения 
для дескриптора доступа, определяемого вторым операндом. 
В скопированной записи сбрасывается бит права на удаление. 
Количество операндов. 2 

Примечание. Как и в остальных аналогичных случаях, если в 
дескрипторе доступа, куда должен быть помещен результат, 
флаги удаления установлены в 1, возникает ошибка типа «сти¬ 
рание дескрипторов доступа, ф лаги удаления которых не 
сброшены». 

Имя команды. NULL-ACCESS.DESCRIPTOR 110..111110 
Выполняемая операция. В адресуемом дескрипторе доступа 
сбрасывается флаг готовности. 

Количество операндов. 1 

Имя команды. INSPECT-ACCESS-DESCRIPTOR 01..011001 
Выполняемая операция. В сегменте данных сохраняется побито¬ 
вая структура адресуемого дескриптора доступа. 

Количество операндов. 2 
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Имя команды. INSPECT-ACCESS 011..011001 

Для заданного дескриптора доступа производится выдача в 
определенном формате информации (например, о правах, ти¬ 
пах) об объекте, адресуемом этим дескриптором доступа. 
Количество операндов. 2 

Имя команды. RESTRJCT-RIGHTS 011..100101 

Выполняемая операция. Данная команда ограничивает права 

доступа в дескрипторе доступа. 

Количество операндов. 2 

Первый операнд адресует порядковое число, рассматривае¬ 
мое как объект «управление дескриптором». Второй операнд 
является селектором дескриптора доступа, права доступа в ко¬ 
тором должны быть изменены. Новые значения битов прав 
объекта, прав системы и хип-флага в дескрипторе доступа фор¬ 
мируются как дизъюнкция (логическое ИЛИ) соответствующих 
значений в исходном дескрипторе доступа и в объекте «управ¬ 
ление дескриптором». В результате права доступа либо сохра¬ 
няются прежними, либо ограничиваются. Если в объекте «уп¬ 
равление дескриптором» установлен флаг проверки типа, а зна¬ 
чения типов объектов в объекте «управление дескриптором» и 
в адресуемом дескриптором доступа сегменте не совпадают, то 
регистрируется ошибка. 

Имя команды. AMPLIFY-RIGHTS 1001..1000 
Выполняемая операция. Данная команда расширяет права дос¬ 
тупа в дескрипторе доступа на основании данных из объекта 
«управление дескриптором». 

Количество операндов. 2 

Первый операнд адресует объект «управление дескрипто¬ 
ром», а второй —дескриптор доступа, права доступа в котором 
должны быть изменены. Из объекта «управление дескриптором» 
в дескриптор доступа переносятся значения битов прав объек¬ 
та, системы и хип-флага. Если в объекте «управление дескрип¬ 
тором» флаг проверки типа установлен в 1, а значения типов в 
этом объекте и в адресуемом дескриптором доступа сегменте не 
совпадают, то регистрируется ошибка. 

Примечание. Первый операнд данной команды в отличие от 
команды RESTRICT-RIGHTS должен быть адресной ссылкой 
на действительный объект «управление дескриптором». 

КОМАНДЫ, СВЯЗАННЫЕ С УПРАВЛЕНИЕМ 
ПРОЦЕССАМИ И ПРОЦЕССОРАМИ 

Имя команды. SEND 01111..1000 

Выполняемая операция. Объект (сообщение) ставится в оче¬ 
редь к порту в соответствии с установленными для него пра- 
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вилами обслуживания. Если память в очереди порта исчерпана 
или отсутствует, транспортер процесса ставится в очередь, а вы¬ 
полнение процесса приостанавливается до тех пор, пока не бу¬ 
дет выделена требуемая память для очереди. 

Количество операндов. 2 

Первый операнд адресует объект «порт». Второй может ад¬ 
ресовать любой объект через дескриптор доступа. 

Имя команды. CONDITIONAL-SEND 10111..0010 

Выполняемая операция. Объект (сообщение) ставится в оче¬ 
редь к порту в соответствии с установленными для порта пра¬ 
вилами обслуживания, если имеется свободная память в оче¬ 
реди. Символьной переменной, на которую ссылается один из 
операндов команды, присваивается логическое значение «ис¬ 
тинно». В противном случае ни объект, ни носитель процесса 
в очередь не ставятся, а указанной символьной переменной при¬ 
сваивается логическое значение «ложно». 

Количество операндов. 3 

Первый операнд адресует объект «порт». Второй может ад¬ 
ресовать любой объект через дескриптор доступа. Третий опе¬ 
ранд адресует символьные данные длиной 1 байт. 

Имя команды. SURROGATE-SEND 11..110011 
Выполняемая операция. Объект (сообщение) посредством тран¬ 
спортера-заменителя ставится в очередь к порту в соответствии 
с установленными Для порта правилами обслуживания. 
Количество операндов. 4 

Первый операнд адресует первый (вспомогательный) порт, 
второй — через дескриптор доступа может произвести обраще¬ 
ние к любому объекту. Третий операнд адресует транспортер, 
а четвертый — еще один порт, куда должно быть переслано со¬ 
общение. Когда второй порт располагает достаточным местом 
для сообщения, транспортер автоматически пересылается к 
нему. 

Примечание. Команда выполняется аналогично команде SEND, 
за исключением того, что отсутствует риск возможной приоста¬ 
новки выполнения процесса. Используемый здесь транспортер 
должен быть независимым объектом (т. е. не транспортером 
данного процесса). 

Имя команды. RECEIVE 0111..111110 

Выполняемая операция. Из очереди к указанному порту уда¬ 
ляется первый объект (сообщение). Дескриптор доступа к это¬ 
му объекту помещается в транспортер процесса. Если очередь 
пуста, транспортер процесса ставится в эту очередь и выполне¬ 
ние процесса приостанавливается до получения сообщения. 



Количество операндов. 1 (адрес порта). 

Имя команды. CONDITIONAL-RECEIVE 11111..1000 
Выполняемая операция. Из очереди к указанному порту (если 
она не пуста) исключается первый .объект (сообщение). Дес¬ 
криптор доступа к этому объекту помещается в транспортер 
процесса. По адресу символьного операнда помещается логичес¬ 
кая величина «истинно». Если же очередь пуста, то по указан¬ 
ному адресу помещается величина «ложно». 

Количество операндов. 2 

Первый операнд адресует объект «порт», второй — символь¬ 
ные данные длиной 1 байт. 

Имя команды. SURROGATE-RECEIVE 111..011001 
Выполняемая операция. Из очереди к указанному порту (если 
она не пуста) исключается первый объект (сообщение). Де¬ 
скриптор доступа к этому объекту помещается в транспортер- 
заменитель, который пересылается к другому порту. Если же 
очередь пуста, то указанный транспортер ставится в очередь на 
получение данных из этого порта. 

Количество операндов. 3 

Первый операнд адресует объект «порт», второй — объект 
«транспортер», а третий — еще один объект «порт». 

Имя команды. DELAY 1111..111110 

Выполняемая операция. Выполнение процесса приостанавлива¬ 
ется на указанный интервал времени. Для этого процесс ста¬ 
вится в очередь к специальному порту диспетчеризации, назы¬ 
ваемому портом задержки (дескриптор доступа к этому порту 
находится в объекте «процессор»). 

Количество операндов. 1 

Операнд является адресом короткого порядкового числа. 
Значение этого числа является величиной требуемой временной 
задержки, исчисляемой в единицах времени внешнего тактового 
генератора (одна временная единица равна 100 мкс). 

Имя команды. READ-PROCESS-CLOCK 011..000001 
Выполняемая операция. Суммарное значение времени, в тече¬ 
ние которого процессор выполнял операции данного процесса, 
помещается в виде порядкового числа по адресу, задаваемому 
операндом команды. 

Количество операндов. 1 

Имя команды. READ-PROCESSOR-STATUS-AND-CLOCK 
111...000001 

Выполняемая операция. Две 16-битовые величины — системное 
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время процесса и состояние процессора — помещаются как по¬ 
рядковое число по адресу, задаваемому операндом команды. 
Количество операндов. 1 

Примечание. Информация о состоянии процессора содержится, 
в той же форме, как и информация в объекте «процессор» (см. 
гл. 17), хотя и извлекается непосредственно из соответствую¬ 
щих микросхем. 

Имя команды. SEND-TO-PROCESSOR 0111.. 1100 
Выполняемая операция. Блокируется сегмент локальных связей 
процессора, которому должно быть послано сообщение. Анали¬ 
зируется значение в поле счетчика откликов в этом сегменте: 
если это значение не равно нулю, сегмент деблокируется и ад¬ 
ресуемой символьной переменной присваивается значение «лож¬ 
но», в противном случае в сегмент связи копируется значение- 
определенного допустимого межпроцессорного сообщения. Зна¬ 
чение в поле счетчика откликов в этом сегменте устанавливает¬ 
ся равным 1, сегмент деблокируется, адресуемой символьной- 
переменной присваивается значение «истинно» и на шину памя¬ 
ти выставляется межпроцессорный сигнал с идентификатором 
процессора-получателя. 

Количество операндов. 3 

Первый операнд адресует процессор-получатель (его объект 
«процессор»), второй операнд — короткое порядковое число, 
имеющее вид соответствующего межпроцессорного сообщения. 
Например, как отмечалось в гл. 17, такими сообщениями могут 
быть: «Пуск процессора», «Войти в режим реконфигурации» и- 
т. п. Третий операнд . адресует символьные данные длиной- 
1 байт. 

Имя команды. BROADCAST-TO-PROCESSORS 1111..1100 
Выполняемая операция. Блокируется сегмент глобальных свя¬ 
зей. Анализируется значение в поле счетчика откликов в этом 
сегменте: если это значение не равно нулю, сегмент деблокиру¬ 
ется и адресуемой символьной переменной присваивается значе¬ 
ние «ложно»; в противном случае в сегмент связи копируется 
значение определенного допустимого межпроцессорного сообще¬ 
ния. В поле счетчика откликов в этом сегменте пoмeщaeтcя^ 
значение из его поля счетчика процессоров, сегмент деблокиру¬ 
ется, адресуемой символьной переменной присваивается значе¬ 
ние «истинно» и на шину памяти поступает межпроцессорный 
сигнал с идентификатором 0 (обозначающим обращение ко- 
всем процессорам). 

Количество операндов. 3 

Первый операнд адресует любой объект «процессор», сег¬ 
мент доступа которого содержит обращение к глобальному сег- 
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менту доступа. Два остальных операнда такие же, как в 
команде SEND-TO-PROCESSOR 

Имя команды. MOVE-TO-INTERCONNECT 01111..0010 
Выполняемая операция. Осуществляется пересылка данных в 
несколько системных регистров, не входящих в процессор, или 
из подобных регистров. Назначение этих регистров зависит от 
.конфигурации системы и здесь обсуждению не подлежит. 


КОМАНДЫ СИНХРОНИЗАЦИИ 

Имя команды. LOCK-OBJECT OIL. 1100 

Выполняемая операция. Если указываемая блокировка не уста¬ 
новлена (два младших бита равны нулю), она устанавливается 
(упомянутым битам присваивается значение 10), а адресуемой 
символьной переменной присваивается значение «истинно». 
В противном случае указанной символьной переменной при¬ 
сваивается значение «ложно». 

Количество операндов. 3 

Первый операнд адресует сегмент данных, второй — корот¬ 
кое порядковое число, значение которого используется в каче¬ 
стве смещения 16-битового объекта «блокировка» внутри сег¬ 
мента. Третий операнд адресует символьные данные длиной 
1 байт. 

Примечание. Поскольку при выполнении команды имеет место 
модификация сегмента, в дескрипторе доступа к нему должны 
иметься права записи. На время между анализом того, имеется 
блокировка или нет, и ее установлением шина памяти захваты¬ 
вается монопольно. 

Имя команды. UNLOCK-OBJECT 0011..1000 

Выполняемая операция. Деблокировка (двум младшим битам 

присваивается значение 00). 

Количество операндов. 2 

Операнды подобны первым двум операндам команды LOCK- 
OBJECT. 


Имя команды. INDIVISIBLY-ADD-SHORT-ORDINAL 1011..1000 
Имя команды. INDIVISIBLY-ADD-ORDINAL 0111..0100 
Выполняемая операция. Суммируются значения двух операндов. 
На время от выборки операндов до записи результата шина па¬ 
мяти захватывается монопольно. 

Количество операндов. 2 
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ПОРЯДОК РАБОТЫ СО СТЕКОМ 

Как уже отмечалось, один или несколько операндов команды 
могут адресоваться к данным, находящимся в стеке. Кроме то¬ 
го, стек может использоваться и для формирования адресных 
ссылок при обращении к данным. Вследствие этого следует уде¬ 
лять особое внимание последовательности расположения дан¬ 
ных в стеке. 

Наиболее естественный способ получения представления 
этой последовательности состоит в описании порядка, в кото¬ 
ром обработка команды выполняется аппаратными средствами. 
При этом следует помнить, что извлечение данных из стека 
происходит всякий раз, когда к стеку производится обращение 
за адресом или данными. Единственное исключение составляет 
копирование значения содержимого стека по команде SAVE. 

Машина обрабатывает операнды последовательно: первый 
операнд, второй и т. д. При обработке каждого операнда вна¬ 
чале формируется адрес, а затем извлекаются данные (выбор¬ 
ка данных осуществляется до начала обработки следующего 
операнда). При формировании адреса с помощью стека, компо¬ 
ненты адреса выбираются в следующем порядке: база, ин¬ 
декс, затем селектор операнда. 


АССОЦИАТИВНОЕ ПРЕОБРАЗОВАНИЕ 
АДРЕСОВ 

АППАРАТНЫМИ СРЕДСТВАМИ 

Архитектуре общего процессора данных системы іАРХ 432 свой¬ 
ственна определенная избыточность (проявляющаяся, например г 
в многочисленных обращениях к памяти) при выполнении даже 
простых операций. Однако степень избыточности на самом деле- 
значительно сокращается благодаря нескольким схемным осо¬ 
бенностям реализации системы. Отметим основные из них. 

1. Часть наиболее часто обновляемых данных из объектов' 
«процессор» и «процесс», такие, как время процессора, время 
процесса или указатель команд, может сниматься непосредст¬ 
венно с соответствующих элементов микросхем. Во время ак¬ 
тивного состояния процессоров и процессов эта информация в 
соответствующих объектах может оказаться неточной. 

2. Во время обработки процессором процесса в заданном 
контексте часть данных, связанных с адресацией, переводите» 
в физические адреса и сохраняется в микросхемах процессора. 
К этим данным относятся: физические адреса сегментов досту¬ 
па и сегментов данных, связанных с объектами «процессор»,, 
«процесс», «контекст», «порт диспетчеризации», «справочник 
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таблиц объектов», а также физические адреса и длины ВСД 
контекста. 

3. Для размещения адресных ссылок (выборки данных по 
указываемым адресам) в микросхемах процессора предусмот¬ 
рено два блока ассоциативной памяти. 

В первом блоке ассоциативной памяти содержится информа¬ 
ция об адресах четырех сегментов данных, к которым выпол¬ 
нялись последние обращения. Благодаря этой информации про¬ 
цессор может непосредственно переходить от значения селек¬ 
тора объекта в адресе данных к необходимому сегменту В ре¬ 
альной памяти, не обращаясь к контексту, ВСД, справочнику 
таблиц объектов и таблице объектов. В каждой из четырех за¬ 
писей этого блока памяти содержится информация, извлекае¬ 
мая из адреса данных, дескриптора доступа и дескриптора 
объекта, определявшихся при нахождении соответствующего 
сегмента при последнем обращении к сегменту, когда данные о 
нем еще не находились в ассоциативной памяти. Эта информа¬ 
ция включает селектор объекта (номер уровня ВСД и индекс 
ВСД), физический или «базовый» адрес, длину сегмента, флаг 
изменения, права чтения/записи. 

Код селектора объекта представляет собой исходные дан¬ 
ные для поиска объекта, выполняемого процессором. Если 
в ассоциативной памяти находится нужный код, то процессор 
сразу получает физический адрес сегмента. Если же требуемо¬ 
го кода селектора в памяти нет, выполняется обычный процесс 
-адресации и параметры, определенные в процессе вычисления 
адреса, запоминаются вместо «наиболее старой» записи в блоке 
ассоциативной памяти. 

Как отмечено выше, в число параметров, запоминаемых в 
записях ассоциативной памяти, включен флаг изменения. Это 
•связано с тем, что, если значение этого флага равно 0 и коман¬ 
дой предусматривается запись в сегмент данных, то ограничить¬ 
ся данными ассоциативной памяти невозможно и процессор 
должен провести обычный процесс адресации и найти дескрип¬ 
тор объекта, чтобы значение флага изменения в нем устано¬ 
вить в 1. 

Другим блоком ассоциативной памяти является буфер спра- 
-вочника таблиц объектов. В нем сохраняется информация о 
двух элементах справочника таблиц объектов, к которым вы¬ 
полнялись последние обращения. Это повышает эффективность 
адресации в случаях, когда не удается отыскать нужный код 
в первом блоке ассоциативной памяти. Новая запись в буфер 
заносится каждый раз, когда в процессе адресации требуется 
обращение к справочнику таблиц объектов. Эта запись включа- 
-ет следующую информацию: индекс справочника, базовый ад- 
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рес (физический адрес таблицы объектов); длину таблицы объ¬ 
ектов; флаг изменения. 

Значение индекса справочника используется, в частности, 
процессором при установлении адресации через справочник 
таблиц объектов. 

На основании вышеизложенного можно было заметить, что 
в рассматриваемой мультипроцессорной системе возможны со¬ 
стояния, когда изменение данных в памяти одним из процессо¬ 
ров приведет к наличию некорректной информации в буферах 
адресации в другом процессоре. Примером может служить ус¬ 
тановление признака неготовности в дескрипторе некоторого 
объекта определенным процессором (например, операционной 
системой) одного из процессоров, в то время как какой-либо 
из процессов другого процессора продолжает пользоваться со¬ 
ответствующим сегментом. То же может произойти и с други¬ 
ми данными (имеющими отношение, например, к процессам или 
контекстам), хранимыми и выбираемыми непосредственно из 
микросхем процессоров. 

Эти сложности преодолеваются с помощью средств переда¬ 
чи сообщений бездействующим процессорам, рассмотренных 
в гл. 17. Когда процессор обнаруживает состояния, при которых 
хранимые и выбираемые непосредственно из микросхем других 
процессоров данные оказываются недействительными (напри¬ 
мер, устаревшими вследствие изменений, внесенных в таблицу 
объектов), он автоматически посылает соответствующее опове¬ 
щающее сообщение всем остальным процессорам. Функции об¬ 
мена устаревших значений параметров, хранимых непосредст¬ 
венно микросхемами процессоров, предоставляются также и 
программам (например, операционной системе) командами 
SEND-TO-PROCESSOR и BROADCAST-TO-PROCESSORS. Для 
этого могут использоваться следующие типы сообщений без¬ 
действующим процессорам: 

1. «Сделать недействительной информацию в кэш-памяти 
сегмента данных», что вызовет очистку принимающими процес¬ 
сорами первого из указанных выше буферов адресации. 

2. «Сделать недействительной информацию в кэш-памяти 
таблицы объектов», что вызовет очистку принимающими про¬ 
цессорами обоих буферов адресации. 

3. «Приостановить выполнение и установить заново инфор¬ 
мацию контекста», что, как и предыдущее сообщение, вызовет 
очистку обоих буферов, а также обновление процессорами хра¬ 
нимой в их микросхемах и связанной с контекстами информа¬ 
ции по данным текущего объекта «контекст». 

4. «Приостановить выполнение и установить заново инфор¬ 
мацию процесса», что приведет к реализации всех упомянутых 
выше действий, а также вызовет обновление принимающими 
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процессорами хранимой в их микросхемах информации, связан¬ 
ной с объектами «процесс». 

5. «Приостановить работу и установить заново информацию 
процессора», что приведет к реализации всех упомянутых выше 
действий, а также вызовет обновление принимающими процес¬ 
сорами хранимой в их микросхемах информации, связанной с 
объектами «процессор». 

6. «Приостановить работу и установить заново всю инфор¬ 
мацию процессора», что приведет к реализации всех упомяну¬ 
тых выше действий, а также вызовет полную начальную уста¬ 
новку процессора при очередном запуске системы. 


УПРАЖНЕНИЯ 

18.1. В приведенном наборе команд отсутствует команда EQUAL- 
INTEGERS. Для сравнения целых чисел можно пользоваться командой 
EQUAL-ORDINAL, поскольку и целые, и порядковые числа представляются 
32-битовыми значениями и для проверки на равенство достаточно провести 
побитовое сравнение (отсутствует необходимость в специальной обработке 
знака числа). Почему тогда для сравнения вещественных чисел разработана 
специальная команда EQUAL-REAL, хотя вещественные числа представляют¬ 
ся также 32 бит? 

18.2. В целях практики формирования адресных ссылок к данным рас¬ 
шифруйте код следующей команды (КОП расположен слева): 

011110000000000000000000111111110011000000000100110100001001000011000000110 

Пояснение. Расшифровку выполняйте справа налево. Данная команда являет¬ 
ся командой сравнения. 


» То есть команда сравнения целых чисел. — Прим, перев. 



ЧАСТЬ VII 

АРХИТЕКТУРА БАЗЫ ДАННЫХ 


ГЛАВА 19 

СИСТЕМЫ С АССОЦИАТИВНОЙ ПАМЯТЬЮ 

Как упоминалось в гл. 2, традиционным машинам присущи раз¬ 
нообразные по типу семантические разрывы между их архитек¬ 
турой и языками программирования. Один из них связан с 
проблемами записи и чтения информации долговременного хра¬ 
нения, т. е. с проблемами обслуживания баз данных (БД). На¬ 
пример, прикладная программа может обратиться к системе уп¬ 
равления базой данных (СУБД) с запросом: «Выдать фамилии 
тех сотрудников 42-го отдела, зарплата которых превышает 
зарплату их непосредственных начальников и которым до пен¬ 
сии осталось работать менее 10 лет». Наличие семантического 
разрыва выявляет хорошо заметная разница между такой со¬ 
держательной формой запроса и фактическими командами ин¬ 
терфейса ввода-вывода: «Блок головок дисковода с адресом 190 
переместить на цилиндр 47» и «Прочитать четвертый сегмент 
на седьмой дорожке магнитного диска». 

В настоящее время подобный семантический разрыв компен¬ 
сируется введением нескольких уровней программного обеспе¬ 
чения (уровней интерпретации), на каждом из которых выпол¬ 
няется преобразование (интерпретация) запроса. Так, интер¬ 
претирующая программа СУБД преобразует исходный запрос 
в группу операций над конкретными наборами данных (фай¬ 
лами). Программа управления файлами преобразует эти опера¬ 
ции в команды супервизора ввода-вывода. Последний форми¬ 
рует команды поиска, чтения и записи для исполнения модуля¬ 
ми обмена, предназначенными для работы с определенными 
устройствами. Наконец, планировщик ввода-вывода для конк¬ 
ретных устройств инициирует запрошенные операции обмена и 
обрабатывает возникающие прерывания. Система такого мно¬ 
гоуровневого преобразования запросов является весьма неэф¬ 
фективным средством сокращения семантического разрыва по 
следующим трем причинам. Во-первых, отсутствует паралле¬ 
лизм в работе: команды каждого уровня интерпретации, как 
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правило, выполняются последовательно одним процессором. Во- 
вторых, правила доступа к информации БД (например, на маг¬ 
нитных дисках) обычно накладывают ограничения на длину 
одновременно обрабатываемых данных: она соответствует дли¬ 
не слова или записи. В-третьих, возможности обработки данных 
ограничены средствами процессора, выполняющего программу 
данного уровня интерпретации. Как следствие обработка срав¬ 
нительно несложных запросов к БД, подобных приведенным вы¬ 
ше в качестве примера, может вызвать пересылку из внешних 
запоминающих устройств (внешних ЗУ) в оперативную память 
ЭВМ больших объемов данных, исчисляемых миллионами би¬ 
тов. 

Очевидным решением описанной проблемы представляется 
использование машины такой архитектуры, которая обеспечи¬ 
вает параллельное выполнение операций над информацией БД, 
одновременную обработку групп данных и возможность обра¬ 
ботки данных без переноса их в оперативную память, т. е. не¬ 
посредственно во внешних ЗУ, где они расположены. 

АДРЕСАЦИЯ ЗНАЧЕНИЯМИ 

Информация, хранимая в ЗУ, характеризуется двумя показате¬ 
лями: адресом и значением (содержимым ячейки памяти с этим 
адресом). Традиционное ЗУ устроено так, что запрос на инфор¬ 
мацию предусматривает задание адреса, результатом же запро¬ 
са является значение (данные), хранимое по этому адресу. По¬ 
добная схема определения местоположения значения по его ад¬ 
ресу удобна для многих применяемых на практике систем 
программирования. В частности, подобная схема необходима 
для реализации оператора присваивания вида 

А:=А+В; 

где А и В — символические имена адресов ячеек памяти. Выпол¬ 
нение этого оператора сводится к извлечению данных, располо¬ 
женных по указанным адресам, их сложению и записи результа¬ 
та на место первого адресата. 

Однако на практике возникает необходимость и в другой, 
обратной форме доступа к данным, когда имеющейся в распо¬ 
ряжении информацией о данных является их значение. Приме¬ 
ром такой ситуации может служить запрос типа: «Увеличить на 
заданную величину все данные, текущее значение которых рав¬ 
но 37». Другим примером, типичным при работе с БД, являет¬ 
ся запрос: «Выдать список сотрудников, зарабатывающих бо¬ 
лее 20 000 долл, в год». Такому запросу наилучшим образом 
соответствует возможность обращения за информацией о дан¬ 
ных, хранимых в ЗУ, по их конкретному значению (20000). 
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При этом в качестве результата должны быть получены адреса 
хранимых в памяти записей, относящихся к сотрудникам, зара¬ 
батывающим более 20 000 долл. 

Возникающая в подобной ситуации проблема связана с тем, 
что операции, подлежащие выполнению с БД, требуют доступа 
к данным по значению, а физический носитель информации 
БД — запоминающая среда — ориентирована на доступ к дан¬ 
ным по адресу. Такое несоответствие становится причиной зна¬ 
чительного семантического разрыва в системе. Как следствие 
этого на программное обеспечение СУБД в качестве первой 
функции возлагается обязанность сокращения указанного раз¬ 
рыва путем преобразования запросов с доступом по значению 
в запросы с доступом по адресу. 

Наиболее простой способ такого преобразования сводится к 
последовательному просмотру всех данных. Однако такое ре¬ 
шение эффективно только при небольших объемах данных. 
Для повышения эффективности в СУБД обычно создают допол¬ 
нительные структуры данных, называемые указателями доступа 
или индексами. Индекс — это структура типа «список», позволя¬ 
ющая преобразовывать требуемые значения данных в адреса 
местоположения этих данных. Поскольку, однако, сами индек¬ 
сы располагаются в памяти, доступ к содержимому которой 
осуществляется посредством адресов, использование индексов 
хотя и сокращает, но полностью не устраняет необходимости 
последовательности поиска. Использование индексов связано 
также со следующими недостатками: 1) повышенной сложно¬ 
стью программного обеспечения; 2) необходимостью дополни¬ 
тельного объема памяти; 3) необходимостью заблаговременно¬ 
го формирования индексов (т. е. предварительного указания 
полей в записях БД, в которых необходимо выполнять поиск); 
4) большими «накладными расходами» на операции добавле¬ 
ния и обновления записей в БД (так, если запись состоит из 
40 полей и в БД организованы индексы для 20 из них, то при 
каждом добавлении одиночной записи СУБД должна обновлять 
20 индексов). 

Эти проблемы могут быть устранены, если использовать ас¬ 
социативную (адресуемую по значению ее содержимого) па¬ 
мять. При работе с запоминающей средой подобного типа вме¬ 
сто запроса «Каково содержимое области с адресом X?» поль¬ 
зуются следующим запросом: «В каких областях памяти по¬ 
ле Y (например, его разряды с 7-го по 35-й) содержит величи¬ 
ны, превышающие 20 000?». 

Ассоциативная память обладает следующими свойствами: 

1) операции в памяти выполняются не над ее отдельными 
элементами, а относятся сразу к группе или даже ко всем эле¬ 
ментам; 
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2) операции в памяти выполняются одновременно над всеми 
ее элементами, подлежащими обработке; 

3) основной операцией в памяти является поиск или сравне¬ 
ние; 

4) время поиска (согласно п. 1—3) не зависит от числа хра¬ 
нимых в памяти элементов. 

На рис. 19.1 изображены основные компоненты ассоциатив¬ 
ной памяти. Таблица элементов памяти — матрица двоичных 
разрядов — состоит из строк — элементов памяти, каждый из 
которых используется, например, для размещения логической 
записи БД, В регистре тестового операнда размещается теку¬ 
щий аргумент поиска (например, число 20000). Регистр маски 
определяет, на какие группы разрядов или поля элементов па¬ 
мяти распространяется действие аргумента поиска. Регистр 
операции определяет операцию, которая должна быть выполне¬ 
на. Типичными операциями являются поиск значения (значе¬ 
ний), равного тестовому; не равного ему; максимального; мини¬ 
мального; принадлежащего диапазону значений; ближайшего 
большего; ближайшего меньшего; меньшего, чем тестовое зна¬ 
чение, и т. п. 

Таблица откликов состоит из строк — элементов длиной не 
менее одного двоичного разряда. Каждый элемент этой табли¬ 
цы используется для регистрации результата выполнения опе¬ 
рации над содержимым элемента памяти, соответствующего 
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данному элементу откликов. Если содержимое текущего элемен¬ 
та памяти удовлетворяет критерию поиска, в разряды соответ¬ 
ствующего элемента таблицы откликов записываются единич¬ 
ные биты. 

Размер регистра тестового операнда (операнда сравнения) 
и регистра маски расширен по сравнению с размером элемента 
памяти на величину, равную размеру элемента таблицы откли¬ 
ков. Это позволяет применять операции поиска как к таблице 
элементов памяти, так и к таблице откликов. Такая возмож¬ 
ность используется для выполнения над содержимым таблицы 
элементов памяти таких операций, как пересечение или объеди¬ 
нение множеств. Это достигается последовательностью опера¬ 
ций, распространяемых и на содержимое таблицы откликов, 
хранящей «отклики» на ранее выполненные операции. 

Для иллюстрации рассмотрим ассоциативную память, со¬ 
держащую записи данных о сотрудниках некоторой организа¬ 
ции. Пусть в разрядах 7—26 каждого элемента памяти содер¬ 
жатся сведения о заработной плате. Для решения задачи отыс¬ 
кания всех сотрудников, зарабатывающих более 20000 долл., 
но не более 25000 долл., достаточно использование трех команд; 

SEARCH >20000 MASK=7..26 

SEARCH (<25000 MASK=7. ,26)AND(=TRUE MASK=RA) 

READ =TRUE MASK=RA 

По первой команде выполняется одновременный просмотр 
разрядов 7—26 всех элементов памяти. Для каждого элемента, 
содержимое разрядов 7—26 которого окажется более 20 000, 
будет записана двоичная единица в соответствующий однораз¬ 
рядный элемент таблицы откликов (RA). Для остальных эле¬ 
ментов памяти в соответствующие элементы таблицы откликов 
записываются двоичные нули. Во второй команде заданы два 
условия. По этой команде требуется записать двоичные едини¬ 
цы в элементы таблицы откликов только для тех записей, для 
которых эти одноразрядные элементы уже получили двоичные 
единицы в результате предшествующей операции и для которых 
содержимое поля заработной платы (разряды 7—26 элементов 
памяти) меньше или равно 25000 долл. Для остальных элемен¬ 
тов памяти в соответствующие элементы таблицы откликов за¬ 
писываются двоичные нули. Третья команда осуществляет вы¬ 
вод записей (содержимого элементов памяти), соответствую¬ 
щие элементы таблицы откликов которых содержат двоичные 
единицы. 

ЧАСТИЧНАЯ АССОЦИАТИВНОСТЬ 

Очевидным недостатком ассоциативной организации памяти 
является ее высокая стоимость. Память, изображенная схема¬ 
тически на рис. 19.1, обеспечивает выполнение разнообразных 
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логических операций типа сравнения для каждого двоичного 
разряда таблицы элементов памяти. Поэтому в ней не мо¬ 
жет быть достигнута такая плотность хранения данных, как 
при традиционных формах организации памяти. Например, 
каждая запись в модуле ассоциативной памяти серии 10115 
фирмы Signetics состоит всего лишь из 16 разрядов. Однако 
известны компромиссные решения, позволяющие в значительной 
степени сохранять достоинства ассоциативной памяти при при¬ 
емлемой стоимости подобной памяти. 

Отметим четыре основных типа организации ассоциативной 
памяти [1]. Первый тип организации (ему соответствует схе¬ 
ма на рис. 19.1)— память с полным параллельным доступом. 
Примером конкретного технического решения организации па¬ 
мяти такого типа может служить память системы РЕРЕ фирмы 
Bell Laboratories [2]. Для этой системы характерна высокая 
степень параллелизма при обращении к данным в памяти. 

Ассоциативная память второго типа организации — это па¬ 
мять с последовательной обработкой разрядов записей. Здесь 
логические операции сравнения определены только для одиноч¬ 
ного разряда данных, а не для всех разрядов одновременно. 
Чтобы выполнить поиск в поле, образуемом разрядами 7—26, 
сначала необходимо сформировать команду для одновременно¬ 
го просмотра и обработки во всех записях только одного 7-го 
разряда, затем 8-го и т. п. Память подобного типа также обла¬ 
дает упомянутыми в предыдущем разделе четырьмя характе¬ 
ристиками ассоциативной памяти с той лишь оговоркой, что 
операции в памяти представляются в виде циклов операций над 
отдельными разрядами и длительность выполнения операции 
пропорциональна длине анализируемого поля. Примером памя¬ 
ти с высокой степенью параллелизма доступа и последователь¬ 
ной обработкой разрядов может служить память системы 
STARAN [3]. 

Ассоциативная память третьего типа организации — это па¬ 
мять с последовательной обработкой слов. Здесь логические 
операции сравнения определены только для одиночного элемен¬ 
та памяти. Адресация значениями достигается при этом после¬ 
довательным применением логических операций к отдельным 
словам — записям в памяти. Это по существу системы, в кото¬ 
рых последовательный поиск реализуется аппаратно. Примером 
может служить выполнение команды SEARCH в системе 
SWARD. Однако, поскольку при последовательной обработке 
слов некоторые из упоминавшихся выше свойств ассоциативной 
памяти (одновременность операций и независимость длительно¬ 
сти поиска от числа элементов в памяти) отсутствуют, та¬ 
кие системы не могут в полной мере считаться системами с ас¬ 
социативной памятью. 
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Ассоциативная память 
четвертого типа органи¬ 
зации — это так называе¬ 
мая частично ассоциатив¬ 
ная память — память, ор¬ 
ганизованная блоками. 

Все элементы памяти 
формируются в п групп. 

Каждая группа элемен¬ 
тов обрабатывается па¬ 
раллельно со всеми дру¬ 
гими группами элементов 
путем последовательного 
перехода от одного эле¬ 
мента группы к другому, 
позволяющие последовательно выбирать элементы из групп 
для применения к ним заданных логических операций. Посколь¬ 
ку элементы в группах выбираются последовательно, оказыва¬ 
ется возможным ограничиться использованием устройств памя¬ 
ти последовательного доступа вместо более дорогостоящих уст¬ 
ройств прямого доступа. 

На рис. 19.2 показан наиболее распространенный вариант 
реализации памяти, организованной блоками. Каждый блок 
представляет собой замкнутую цепочку элементов памяти 
(кольцо), которая в частном случае может быть построена на 
регистрах сдвига. Когда элемент памяти обрабатывается меха¬ 
низмом чтения — записи, над его содержимым выполняются ло¬ 
гические операции ассоциативной обработки (обозначаемые на 
рис. 19.2 как AL). 

Организация ассоциативной памяти блоками является ком¬ 
промиссным решением проблемы одновременности выполнения 
операций над содержимым всех элементов памяти (согласно 
второму свойству ассоциативной памяти). При этом происходит 
одновременное выполнение операций не над содержимым всех 
элементов памяти, а над содержимым группы элементов, взя¬ 
тых по одному из каждого блока, причем в пределах каждого 
блока элементы памяти обрабатываются последовательно. 
Привлекательной чертой такого способа организации памяти 
является то, что он предоставляет широкие возможности для 
модификации структуры подобной памяти, исходя из требова¬ 
ний ее стоимости, быстродействия, необходимых характеристик 
хранения данных и выполнения логических операций. Одним 
предельным вариантом организации подобной памяти является 
структура, каждый блок которой состоит только из одного эле¬ 
мента памяти (т. е. это вариант полностью параллельного до¬ 
ступа к данным, соответствующий рис. 19.1). Другой предель- 



Следовательно, требуются средства, 
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ный вариант построения подобной памяти предполагает нали¬ 
чие единственного блока элементов памяти — вариант последо¬ 
вательной обработки слов. 

Скорость обработки в памяти, организованной блоками, мо¬ 
жет достигать значительной величины. Далеко не самая мощ¬ 
ная система может состоять из 1000 блоков, в каждом из кото¬ 
рых находится до 200 записей. Допустим, что данные переме¬ 
щаются со скоростью (частотой) 100 циклов (оборотов кольца 
элементов памяти) в секунду. Пусть также в схемах ассоциа¬ 
тивной логики предусмотрена возможность одновременной об¬ 
работки трех полей записи (т. е. обработки запросов типа: 
«Выявить всех налогоплательщиков 1946 года рождения, не 
состоящих в браке и зарабатывающих менее 15000 долл.»). 
Эта операция может быть выполнена над всем множеством 
данных, включающим 200 000 записей, за 10 млс (один оборот 
кольца элементов памяти). Можно подсчитать среднюю частоту 
выполнения операций сравнения. В данном случае она оказы¬ 
вается равной 60 млн. операций сравнения в секунду 1 ». Это на 
много порядков выше соответствующих показателей для памя¬ 
ти с традиционной организацией. 

Циклический просмотр данных может быть выполнен разны¬ 
ми способами. Во-первых, в качестве памяти можно воспользо¬ 
ваться вращающимися магнитными дисками. При этом логи¬ 
ческие схемы ассоциативной обработки подключаются к голов¬ 
кам считывания и записи. Во-вторых, можно использовать ре¬ 
гистры сдвига на базе элементов с зарядовой связью и элемен¬ 
тов памяти на ЦМД (цилиндрических магнитных доменах), 
именуемой также пузырьковой памятью. 

В зависимости от особенностей выбранной технологической 
базы для памяти с блочной организацией и, в частности, от 
быстродействия перемещения данных возможны различные спо¬ 
собы организации передвижения данных внутри блока (по коль¬ 
цу элементов памяти). Пусть записи состоят из последователь¬ 
ностей символов, а символы представляются последовательно¬ 
стью значений восьми двоичных разрядов. Наиболее типичную 
форму представления данных можно охарактеризовать как по¬ 
следовательную по разрядам и по словам. В этом случае каж¬ 
дая запись располагается целиком в одном кольце. Другая фор¬ 
ма представления является последовательной по разрядам и 
параллельной по словам. В этом случае данные каждой записи 
распределяются между п кольцами, где л —число символов в 


11 Единицей подсчета является операция сравнения полей записей. Для 
более элементарной операции сравнения одиночных двоичных разрядов зна¬ 
чение частоты еще выше. — Прим, перев. 



СИСТЕМЫ С АССОЦИАТИВНОЙ ПАМЯТЬЮ 171 


записи; каждый символ располагается в единственном своем 
кольце. 

Существует также такая форма представления данных в па¬ 
мяти с блочной организацией, как параллельное представление 
по разрядам и последовательное по словам при условии объ¬ 
единения колец в группы по восемь. Каждая запись и каждый 
символ в любой записи представляются данными восьми колец: 
первые разряды в группе колец дают компоненты представле¬ 
ния первого символа первой записи, вторые разряды образуют 
второй символ первой записи и т. д. Наконец, возможно сле¬ 
дующее представление данных: параллельное как по разрядам, 
так и по словам. Число используемых при этом колец равно 8п. 
При этом первые разряды, считываемые со всех 8п колец отно¬ 
сятся к первой записи, вторые — ко второй и т. д. 

Отметим, что в частично-ассоциативной памяти, построенной 
на основе памяти на ЦМД, предпочтительнее не пользоваться 
представлением данных, последовательным как по разрядам, 
так и по словам, поскольку для этой технологии характерны не¬ 
высокие скорости обмена. 

ПРИМЕНЕНИЕ АССОЦИАТИВНОЙ ПАМЯТИ 
ПРИ ПОСТРОЕНИИ БАЗ ДАННЫХ 

Значительные достоинства ассоциативной памяти проявляются 
при построении баз данных (см. гл. 20). Наиболее очевидное 
из них — высокая скорость поиска и извлечения требуемых дан¬ 
ных. Выше отмечались причины, по которым типичные схемы 
последовательного поиска оказываются неудовлетворительными 
для поддержания работы больших БД, функционирующих в ре¬ 
жиме реального масштаба времени. Хорошим примером боль¬ 
шой БД с жесткими требованиями к ее производительности яв¬ 
ляется база данных авиалинии. Из обзора функциональных за¬ 
дач авиаслужбы [4] можно заключить, что основной объем 
операций по обработке информации приходится на следующие 
службы: 

система резервирования билетов; 

система составления тарифной сетки за проезд; 

система учета перевозимого веса; 

планирование занятости летного состава; 

система резервирования мест в гостиницах; 

регистрация пассажиров; 

служба связи; 

планирование рейсов; 

техническое обслуживание самолетов; 

регистрация багажа. 

Из упомянутого обзора следует, что в 1980 г. для функцио¬ 
нирования крупной авиакомпании характерен большой поток 
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запросов, поступающих с терминалов в СУБД. Он достигает 
интенсивности 175—200 запрос/с. База данных имеет объем, 
равный ~4 млрд. байт. При обработке 175—200 запрос/с вы¬ 
полняется 2400—2800 обменов с файлами БД при среднем объ¬ 
еме информации за один обмен, составляющем 1000 байт. Сред¬ 
няя периодичность обращений составляет 400 мкс. Это намного 
превышает возможности традиционных СУБД, работающих с 
большими массивами данных. Таким образом, очевидны необ¬ 
ходимость перехода авиаслужб в высокой степени проблемно- 
ориентированное программное обеспечение и невозможность эф¬ 
фективной эксплуатации ими СУБД общего назначения. 

В гл. 20 и 21 рассматриваются три экспериментальные 
СУБД, в которых применяются частично-ассоциативные струк¬ 
туры памяти с адресацией значениями. Все эти системы ориен¬ 
тированы на работу со структурами однородных данных. Ко¬ 
нечно, возможности этих систем не отвечают требованиям всего 
разнообразия задач обработки данных. В общем случае систе¬ 
ма должна быть пригодна к обработке неформатизованных 
данных различной структуры. С такой ситуацией мы сталки¬ 
ваемся при обработке запросов типа: «Указать названия всех 
статей из 60 последних выпусков Communications of the ACM, 
в которых рассматриваются вопросы организации и управления 
ассоциативной памятью в контексте ее применения в БД» или 
«Выдать сведения по всем делам федерального суда, связан¬ 
ным с юридическими нарушениями контрактов по использова¬ 
нию вычислительных ресурсов». Для решения подобных задач 
требуются способы организации памяти, отличные от рассмат¬ 
риваемых в двух следующих главах [5—8]. 
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Хорошим примером использования принципа частичной ассоциа¬ 
тивности при создании баз данных является реляционный ассо¬ 
циативный процессор RAP (relational associative processor), 
спроектированный в Университете г. Торонто (Канада) в соот¬ 
ветствии со спецификой реляционной структуры базы данных. 
Процессор использовался в качестве специализированной маши¬ 
ны базы данных [1—11]. 

Поскольку RAP предназначался для проведения различных 
исследований, была запланирована разработка трех вариантов 
этого процессора: RAP.1 —к 1975 г., RAP. 2 — к 1977 г., RAP.3 
находился в стадии разработки во время написания этой книги. 
Рассмотрение проведем на примере процессора RAP. 2 и, кро¬ 
ме того, укажем отличительные особенности процессоров RAP.1 
и RAP.3. 

Общая структура процессора RAP показана на рис. 20.1. 
Предполагается, что процессор RAP работает совместно с ЭВМ 
общего назначения, выполняющей роль так называемой веду¬ 
щей машины. Последняя осуществляет связь с процессором 
RAP, посылая ему RAP -программу. Программа состоит из по¬ 
следовательности команд RAP, описывающих простые или 
сложные запросы к БД. Входящий в состав RAP контроллер 
представляет собой процессор, декодирующий команды RAP - 
программы, управляющий логическими схемами ассоциативно¬ 
го доступа к данным и обеспечивающий взаимосвязь с веду¬ 
щей машиной. Блок статистической обработки, сопряженный с 
контроллером, используется при выполнении числовых опера¬ 
ций над содержимым БД. 

Поскольку процессор RAP ориентирован на так называемые 
реляционные принципы организации БД, перечислим основные 
понятия, имеющие отношение к указанным принципам. 

В традиционном понимании БД — это совокупность логичес¬ 
ких файлов. Последние представляются в виде наборов запи- 
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сей, каждая из которых является совокупностью полей. Записи 
в логическом файле однородны: они содержат одинаковое чис¬ 
ло полей, причем п-е поле некоторой записи служит для хране¬ 
ния данных того же назначения и тех же характеристик, что и 
п-е поле любой другой записи этого логического файла. 

В терминологии реляционных БД логический файл опреде¬ 
ляет отношение, запись называется кортежем, а совокупность 
возможных значений содержимого заданного поля является до¬ 
меном. Имя домена эквивалентно имени поля, его номеру и по- 



Рис. 20.1. Структура процессора RAP. 

зиции в записи. (Ниже термины «домен» и «поле» будут ис¬ 
пользоваться как равнозначные.) Другими словами, отношение 
рассматривается как двумерная таблица, содержимое которой 
определяет набор однотипных данных. Имя таблицы является 
именем отношения, каждая строка — кортежем, столбцы — до¬ 
менами. Реляционная база данных представляет собой множе¬ 
ство отношений, связанных между собой общими доменами. 

В соответствии с реляционными принципами организации 
БД описанию подлежат не только логическая структура БД, но 
и набор основных операций над данными. Так, операции выбо¬ 
ра позволяют в определенном отношении находить кортежи, 
удовлетворяющие группе задаваемых условий. Операция соеди¬ 
нения служит для отбора кортежей из заданного отношения по 
критерию поиска, заданному для другого отношения; связь 
здесь устанавливается по общему для обоих отношений имени 
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домена. На подмножествах отношения определим также набор 
таких традиционных операций, как объединение, пересечение, 
дополнение и вычитание. Операция проектирования позволяет 
из заданного отношения выбрать подмножество доменов, иск¬ 
лючающее дублирование их значений. Операция со свободной 
переменной позволяет отбирать кортежи по значениям доменов 
других кортежей. На доменах обычно задаются также опера¬ 
ции модификации (обновление значений содержимого полей)' 
и арифметические операции. 

ФУНКЦИОНАЛЬНАЯ ЯЧЕЙКА 
ПРОЦЕССОРА RAP 

Система RAP может состоять из сотен отдельных функциональ¬ 
но независимых ячеек, каждая из которых способна выполнять 
операции над содержимым базы данных ассоциативно и одно¬ 
временно с другими подобными ячейками. Структура такой 
ячейки показана на рис. 20.2. В процессоре RAP.1 каждая 
ячейка — это сочетание логических схем обработки и запомина¬ 
ющего устройства вращающегося типа в виде дорожки диска с 



Рис. 20.2. Структура ячейки процессора RAP. 


фиксированной над ней головкой. В процессоре RAP.2 вместо 
описанного запоминающего устройства в ячейке используется 
прибор с зарядовой связью, физически реализованный в виде 
регистра сдвига последовательного типа длиной 1 млн. бит. 
В процессоре RAP.3 в качестве подобной памяти для ячеек 
применяются регистры сдвига, построенные на элементах па¬ 
мяти на Ц МД , а логические схемы обработки реализуются в 
основном на микропроцессорах. 

В каждой ячейке имеется регистр, содержащий имя храни¬ 
мого отношения. Имя может храниться в закодированной фор¬ 
ме. (В процессоре RAP.1 имя отношения хранилось в нача- 
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ле цепочки записей в запоминающем устройстве вращаю¬ 
щегося типа.) Ячейка функционирует следующим образом. При 
прохождении кортежем считывающего механизма содержимое 
кортежа считывается в буфер. После этого логические схемы 
ячейки имеют возможность анализировать домены считанного 
кортежа, и, если необходимо, изменять их содержимое. Если 
имела место модификация, то с помощью механизма записи вы¬ 
полняется обновление соответствующей записи на вращающем¬ 
ся носителе. 

Каждая ячейка процессора RAP.2 содержит три компарато¬ 
ра, благодаря которым возможна одновременная проверка со¬ 
держимого трех доменов кортежа, находящегося в буфере (на¬ 
пример, проверка на равенство некоторому значению, неравен¬ 
ство или превышение его). При этом допускается одновремен¬ 
ное выполнение конъюнкций (И) или дизъюнкций (ИЛИ), но 
комбинации этих операций запрещены. 

В каждой ячейке имеются также регистры для хранения зна¬ 
чений доменов, к которым могут адресоваться RAP -программы. 

ПРЕДСТАВЛЕНИЕ ДАННЫХ 

Физическое представление данных в процессоре RAP адекватно 
реляционной структуре БД. Взаимосвязь данных описывается 
отношениями, кортежами и доменами. Отношение может рас¬ 
пространяться на группу ячеек RAP, но каждая из них может 
содержать кортежи только одного и того же отношения. Физи¬ 
ческие форматы данных в запоминающем устройстве вращаю¬ 
щегося типа ячейки показаны на рис. 20.3. Кодируемая опреде¬ 
ленным образом метка обозначает начало данных (соответст¬ 
вует маркеру дорожки на магнитном диске). Первый блок дан¬ 
ных состоит из имен доменов данного отношения. Имена, как 
правило, хранятся в виде кодов. Кодирование символических 
имен осуществляют программы СУБД, выполняемые ведущей 
машиной. 

Остальные блоки состоят из кортежей данного отношения. 
Первый двоичный разряд (DF) используется для размещения 
флага удаления. Единица, записанная в этот разряд, означает, 
что дальнейшее хранение кортежа не требуется; занимаемое 
этим кортежем место (теперь освободившееся) будет позднее 
учтено, как не занятое, программой «сбора мусора» данной 
ячейки процессора RAP. Содержимое маркерных разрядов со¬ 
ответствует содержимому таблицы откликов, описываемой в 
гл. 19. Кортеж называют Т-маркированным (где Т — любая 
комбинация четырех битов), если в соответствующих данно¬ 
му Т маркерных разрядах находятся единицы. Кортеж считает¬ 
ся Т-немаркированным, если в указанных разрядах содержатся 
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Маркерные 

разряды 


Рис. 20.3. Форматы данных для процессора RAP. 

нули. Посредством команд системы RAP можно записывать 
двоичные единицы или нули в маркерные разряды либо прове¬ 
рять содержимое последних (сравнивая с тестовым значением). 

Остальные поля кортежа содержат значения доменов. Их 
порядок должен совпадать с порядком перечисления имен в 
блоке имен доменов. Каждая хранимая величина может зани¬ 
мать 8, Гб или 32 разряда. В двух разрядах, предшествующих 
подобной величине, указывается длина занимаемого ею поля. 
Величины, имеющие числовые значения, хранятся в виде допол¬ 
нительного кода. Кортеж может содержать не более 255 до¬ 
менов. Перечисленные характеристики и, в частности, предель¬ 
ный размер отдельного поля (домена), являются сильными ог¬ 
раничениями для реальной БД. Однако не следует забывать, 
что RAP — это процессор, предназначенный для изучения дан¬ 
ной проблемы. Кроме того, требуемое кодирование значений 
доменов может быть выполнено ведущей машиной. 

Перед помещением кортежей в ячейку RAP память этой 
ячейки должна быть форматизована. Для этого необходимо, во- 
первых, в регистр отношения данной ячейки загрузить имя от¬ 
ношения, которому принадлежат данные кортежи; во-вторых, 
записать все блоки имен доменов, за которыми следуют блоки 
«пустых» кортежей, пока память не будет исчерпана. При этом 
выполняется также запись кода 11 в первые два разряда дли¬ 
ны первого домена первого кортежа. Этот код символьно обо¬ 
значают как ТКЕ (logical track end — конец логической запи¬ 
си). Система воспринимает ТКЕ как указание на то, что дан¬ 
ный кортеж и все следующие за ним не содержат записей и, 
следовательно, относятся к свободной части памяти. При после¬ 
дующем добавлении в данную ячейку кортежа последний будет 


12-429 





178 ГЛАВА 20 


записываться на пустое место, ранее помеченное кодом ТКЕ. 
При этом код ТКЕ будет перенесен в следующую по порядку 
запись свободной части памяти. Если кортеж удален, то прог¬ 
рамма «сбора» мусора перемещает все имеющиеся кортежи в 
начале дорожки так, что все свободное место концентрируется 
в ее конце. При добавлении нового кортежа система проверяет 
все ячейки процессора RAP, соответствующие данному отноше¬ 
нию, на наличие свободного места. Если свободного места не 
находится, то выделяется и форматизуется еще одна ячейка 
системы RAP. 

Можно заметить, что в данной реализации системы выполне¬ 
ние сбора мусора ничем не оправдано. Поскольку вращающие¬ 
ся носители заранее размечены под возможные кортежи, а вы¬ 
полнение команды системы RAP требует одного или нескольких 
оборотов носителя, перемещение заполненных кортежей в нача¬ 
ло дорожки очевидных преимуществ не дает. 

ФОРМАТ КОМАНД 

Для процессора RAP разработан набор команд, из которых мо¬ 
гут составляться программы. С их помощью выполняются опе¬ 
рации над БД, имеющей реляционную структуру. RAP -програм¬ 
му можно рассматривать как «канальную программу» систе¬ 
мы 370, за исключением того, что семантика команд RAP в 
большей мере согласована с принципами организации БД. 
В дальнейшем эти команды будут представлены не своими ма¬ 
шинными кодами, а символическими средствами языка ассем¬ 
блера. Помимо этого, в приводимых ниже примерах не будут 
соблюдаться правила, ограничивающие длину используемых 
символических имен (например, допустимым будет считаться 
содержимое домена типа „John Smith”). Будем полагать, что 
либо ведущая машина допускает кодирование подобных имен, 
либо ограничение их длины — проблема конкретной реализации 
системы. 

Команды RAP имеют следующий обобщенный формат: 

<метка> <КОП> <маркеры> [<объект>: <условие>] [<пара- 
метр>] 

Символическое имя в поле <метка> не является обяза¬ 
тельным. Оно определяет адрес, используемый в командах пере¬ 
хода. <КОП> — код операции. Поле <маркеры> служит для 
задания группы маркерных разрядов, которые при выпол¬ 
нении команды будут установлены в 1 или 0. Например, содер¬ 
жимое этого поля MARK (А) означает требование установить 
в 1 содержимое маркерного разряда А во всех кортежах, удов¬ 
летворяющих заданному условию. Если же содержимым поля 
<маркеры> является RESET (АВ), то сбросу подлежат раз- 
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ряды А и В во всех кортежах, удовлетворяющих условию. 

Поле <объект> определяет имя отношения, над которым 
выполняется данная операция. В ряде случаев в нем же ука¬ 
зываются и имена доменов в этом отношении. Эта часть коман¬ 
ды имеет следующий формат: 

<Rn> или <Rn> (<D1>, <D2>, ... <Dn>), где <Rn> — имя отно¬ 
шения, a <D1>, <D2>, ... <Dn> — имена доменов. 

Поле <условие> служит для записи логического выраже¬ 
ния, используемого в качестве критерия отбора подмножества 
кортежей, к которым должна применяться операция ассоциа¬ 
тивной адресации. Логическое выражение может иметь одну из 
следующих трех форм: 1) вырожденную форму, эквивалент¬ 
ную отсутствию условия (предполагается, что адресуемы все 
кортежи данного отношения); 2) форму конъюнкции элементар¬ 
ных условий; 3) форму дизъюнкции элементарных условий. 
Элементарное условие в логическом выражении должно иметь 
следующий вид: 

1) <имя><опер. сравнения><операнд> 

2) <Rn>.MKED«T>) 

3) <Rn>.UNMKED«T>) 

В поле <имя> задаются имена отношения и домена в 
форме (<Rn>.<Dn>). В поле <опер.сравнения> указывается 
символ операции сравнения (равно, не равно, меньше, мень¬ 
ше или равно, больше, больше или равно). В поле операн¬ 
да может указываться регистр RAP, литерал или символическое 
имя переменной (адрес) в ведущей машине. При дальнейшем 
изложении материала нечисловые литералы будут заключаться 
в кавычки, а символические имена переменных — в круглые 
скобки. В поле <Т> указывается конкретное содержимое мар¬ 
керных разрядов. Оно может кодироваться одним из следую¬ 
щих способов: А, В, С, D, АВ, АС, AD, ВС, BD, CD, АВС, 
ABD, ACD, BCD и ABCD. 

Приведем пример задания условия: 

ЕМР. SALARY >5000) & (EMP.MKED(A)) 

Согласно этому условию, для ассоциативной обработки вы¬ 
деляются кортежи отношения ЕМР со значением заработка, 
превышающим 5000, в которых содержимым маркерного раз¬ 
ряда А является 1*>. 


*> Здесь и далее имена, используемые в полях команд, являются сокра¬ 
щениями английских слов — названий, принятых в рассматриваемой задаче 
для отношений и доменов. Для удобства читателя приведем сокращения, ис¬ 
пользуемые в данной главе: ЕМР — сотрудник, DEPT — отдел, SAL — зар¬ 
плата, VOL — количество, MGR — управляющий, PARTNUM — шифр товар¬ 
ного изделия. Употребляются также полные имена: SALARY — зарплата, 
NAME — фамилия, ITEM — наименование изделия. — Прим, перев. 


12* 
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Аппаратная реализация накладывает ограничения на форму 
записи составных условий и на допустимое количество исполь¬ 
зуемых при этом элементарных условий. В частности, в процес¬ 
соре RAP.2 составное условие формируется не более чем из 
трех простых. 

Последнее поле <параметр> в формате команд RAP ис¬ 
пользуется только в командах некоторых типов и будет рас¬ 
смотрено позднее, когда возникнет в этом необходимость. 

НАБОР КОМАНД ПРОЦЕССОРА RAP 

Процессор RAP располагает обширным набором машинных 
команд, с помощью которых, используя имеющееся в ведущей 
машине программное обеспечение СУБД, можно создавать 
программы управления БД. Поскольку функции некоторых из 
них весьма сложны, не все эти команды будут описаны полно¬ 
стью. Обсуждение будет ограничено той степенью детальности, 
которая необходима для понимания их функционального назна¬ 
чения. Операции, выполняемые командами, будут рассматри¬ 
ваться на примере БД, изображенной на рис. 20.4. Заметим, что 
у обоих рассматриваемых отношений (ЕМР и ITEM) этой БД 
имеется общий домен DEPT. 

Время выполнения команд удобно исчислять количеством 
циклов обращения носителей запоминающего устройства вра¬ 
щающегося типа. В случае когда это возможно, такая характе¬ 
ристика приводится ниже. Иногда время выполнения зависит от 
особенностей аппаратной реализации системы или от самих 
данных. 

Перейдем к рассмотрению отдельных команд. Команда 
5ELECT(MapKepbi)[(Rn> : (условие)] переводит в нужное 
состояние указанные разряды маркеров всех кортежей отноше¬ 
ния Rn, удовлетворяющих заданному условию. В эти разря¬ 
ды записываются двоичные единицы или нули. Время выпол¬ 
нения равно одному обороту вращающегося носителя (диска). 

Например, если имеется файл сотрудников (отношение) 
ЕМР, то по команде 

SELECT MARK (АВ) [ЕМР : EMP.DEPT=202] 
двоичные единицы записываются в разряды А и В кортежей 
сотрудников, работающих в отделе 202. Команда 
READ-ALL<MapKepu>[<Rn>«Dl>, ...) : (условие)] [(адрес)] 
пересылает удовлетворяющие заданному условию кортежи 
в указанную область ведущей машины. Пересылаться могут 
или все домены выбираемых по условию кортежей или их 
подмножество. Если в команде присутствует поле «марке¬ 
ры», в соответствующие разряды записываются двоичные еди¬ 
ницы или нули. Время выполнения зависит от количества вы- 
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Рис. 20.4. Пример базы данных. 

бираемых кортежей и числа каналов ввода-вывода, связываю¬ 
щих процессор RAP с ведущей машиной. В частности, по 
команде 

READ-ALL[EMP:MGR = 'SMITH'] [BUF] 

из поля ЕМР в поле BUF пересылаются данные о всех сотруд¬ 
никах отдела, возглавляемого Смитом (Smith). С помощью ко¬ 
манды 

READ-ALL [ЕМР (NAME, SAL) : EMP.MKED (A) ],[BUF] 

производится запись в поле BUF фамилии и заработной платы 
(значения доменов NAME и SAL) тех сотрудников, в записях 
которых в данный момент отмечен маркер А. Следующая 
команда 

READ[<n>]<MapKepbi>[<Rn>«Dl>, ...) : <условие>][<адрес>] 

эквивалентна команде READ-ALL, за тем исключением, что в 
память ведущей машины пересылаются не все кортежи, удов¬ 
летворяющие заданному условию, а только первые п из них. 
Заметим, однако, что понятие «первых записей» кортежей в 
системах ассоциативной памяти по существу не определено. 
Все зависит от конкретной реализации процессора RAP, а так- 
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же от того, как именно расположились записи на вращающих¬ 
ся носителях в отдельных ячейках RAP. Команда 

READ-REG [<список регистров)] [<адрес>] 

копирует содержимое указанных регистров RAP в память ве¬ 
дущей машины по заданному адресу. (В процессоре RAP.2 име¬ 
ется три адресуемых регистра.) Время выполнения этой коман¬ 
ды меньше одного оборота вращающегося носителя. Команда 
CROSS-SELECT<Rl MapKepbi>[<Rl>:<Dl><onep. сравнения) 
<R2).<D2>] [<R2).MKED «Т» ] 

присваивает значения содержимому маркерных разрядов корте¬ 
жей отношения R1 в соответствии с результатом сравнения до¬ 
мена D1 отношения R1 и домена D2 отношения R2. При этом 
используется только Т-маркированное содержимое домена D2 
во всех кортежах R2. Конечно, содержимое доменов D1 и D2 
должно допускать сопоставление. Возможна ситуация, при ко¬ 
торой для каждого кортежа R2 имеется более одного корте¬ 
жа R1, удовлетворяющего условию сравнения. 

Команда выполняется за 1+NT2/K+N оборота вращающих¬ 
ся носителей, где NT2 — количество Т-маркированных кортежей 
в R2, N — число ячеек RAP, содержащих Т-маркированные кор¬ 
тежи в R2, а К — величина, зависимая от конкретной реализа¬ 
ции и равная количеству данных отношения R2, которые могут 
одновременно пересылаться в ячейки RAP, содержащие данные 
отношения R1. Рассмотрим последовательность из двух команда 

SELECT MARK(A) [ITEM:ITEM.VOL>1001 
CROSS-SELECT MARK (A) [EMP:EMP.DEPT= ITEM.DEPT1 
[ITEMMKED(A)] 

В результате выполнения второй команды будут отмечены 
записи о служащих, работающих в отделах, где продано более 
100 единиц продукции. 

CROSS-COND-SELECT <R1 маркеры) <врем. маркеры) 
f[<Rl):<Dl)<onep. сравнения) <R2>. <D2>] [<R2).MKED «Т»] 

Эта команда близка к команде CROSS-SELECT. Указанные 
маркеры записей отношения R1 устанавливаются в 0, если ус¬ 
ловие не выполняется. Параметр <врем. маркеры) указывает 
один или несколько маркерных разрядов, которыми можно 
пользоваться во время выполнения данной команды. Такую ко¬ 
манду применяют для получения пересечений (логическое И) 
двух подмножеств одного и того же отношения. Обычно этой 
команде предшествует команда CROSS-SELECT. Время выпол¬ 
нения команды CROSS-COND-SELECT превышает время вы- 
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полнения команды CROSS-SELECT на длительность одного 
цикла. 

Команда 

GET-FIRST-MARK<MapKepbi>[<Rn> (<D 1 >,...): 

<Da> <опер.сравнения> <Db>] [MKED «Т» ] 

используется для выполнения операции проектирования в пре¬ 
делах одного и того же отношения. Значение домена <Db> не¬ 
которого Т-маркированного кортежа последовательно сравни¬ 
вается со значением домена <Da> всех кортежей данного отно¬ 
шения. Значения доменов <Da> и <Db> могут указывать на 
один и тот же или на разные домены отношения. В последнем 
случае в них должны храниться сопоставимые величины. При 
выполнении команды системой производятся следующие дейст¬ 
вия: 1) маркерам всех кортежей, удовлетворяющих заданному 
условию, присваиваются значения в соответствии с содержи¬ 
мым поля <маркеры> данной команды; 2) сбрасывается Т-мар- 
кер кортежа, относительно которого выполнялось сравнение 
и 3) значения указанных доменов (<D1>, ...) этого кортежа 
записываются на хранение в регистры RAP. (В RAP.2 на хра¬ 
нение можно записывать содержимое не более трех полей; для 
этого используются регистры 1—3.) 

Пример использования этой команды будет приведен ниже. 
Время ее выполнения в среднем равно полутора периодам вра¬ 
щения носителя. Команда 

GET-FIRST[<Rn> (<D1>,...)]i[MKED «Т»] 

выполняется подобно предыдущей. В ней, однако, отсутствует 
проверка условия и не маркируются соответствующие кортежи, 
т. е. исключен первый шаг из действий, реализуемых по 
команде GET-FIRST-MARK. Т-маркер того кортежа, в котором 
он был установлен, сбрасывается, а значения указанных доме¬ 
нов этого кортежа загружаются в регистры RAP. По команде 

SAVE(<n»'[<Rn>«Dl>,...):<ycflOBHe>] [<список регистров)] 

в указанные регистры загружаются значения перечисленных 
доменов первых п записей, удовлетворяющих заданному в 
команде условию. Если используется необязательный операнд 
<маркеры>, то кортежи, удовлетворяющие указанному усло¬ 
вию, маркируются. Команда выполняется за время, равное од¬ 
ному циклу. 

Команду GET-FIRST можно рассматривать как частный 
случай более общей команды SAVE. Здесь приводятся обе 
команды вследствие некоторых несоответствий нескольких из¬ 
вестных описаний списка команд RAP.2. 



Рассмотрим пример. В результате выполнения команды 
SAVE(l) [ITEM(PARTNUM) : ITEM.VOL < (MIN)] [REG1] 

система выделит из товарного перечня изделие ITEM, количе¬ 
ство единиц которого (значение домена VOL) меньше значения 
переменной MIN, и поместит шифр этого изделия в регистр 1. 
Следующие команды 

ADD <MapKepbi>[<Rn>(<Dn>) :<условие>1[<операнд>] 

SUB (маркерыжИп) (<Dn>) :<условие>1[<операнд>] 

REPLACE <MapKepH>[<Rn> (<Dn>) :<условие>][<операнд>] 

имеют одинаковый формат. Выполняются они похожим обра¬ 
зом. А именно, требуемая операция 1 » осуществляется над доме¬ 
нами <Dn> всех кортежей, удовлетворяющих заданному усло¬ 
вию. Если содержимое поля <маркеры> определено, то выпол¬ 
няется маркирование указанных кортежей по мере их просмот¬ 
ра системой. Это используется для восстановления работоспо¬ 
собности системы: в таком случае выполнение операции может 
быть возобновлено над множеством неотмеченных записей. Вре¬ 
мя выполнения равно одному периоду обращения носителя. 
Рассмотрим пример. В результате выполнения команды 
SUB [ITEM (VOL) : ITEM.DEPT=410&ITEM.VOL>100] [1] 

1 вычитается из содержимого домена (VOL) количества еди¬ 
ниц различных видов изделий, выпускаемых отделом 410, кото¬ 
рые имеют в этом домене значение более 100. Команды 
SUM <MapKepbi>r<Rn> (<Dn>) : (условие) ][<регистр>] 

MAX <MapKepbi>f<Rn>«Dn>) :<условие>][<регистр>] 

MIN <MapKepbi>[<Rn>(<Dn>) :<условие>][<регистр>] 

COUNT <MapKepbi>[<Rn> (<Dn>) :<условие>][<регистр>] 

задают функции, определенные на множествах. Первые три 
команды (вычисление суммы, максимума и минимума) вычис¬ 
ляют значение функции по множеству значений домена <Dn> 
кортежей, удовлетворяющих заданному в команде условию. 
По команде COUNT подсчитывается количество таких корте¬ 
жей. Вычисленное значение загружается в указанный регистр. 
Если задается операнд <маркеры>, выделенные кортежи мар¬ 
кируются. Время выполнения несколько больше одного перио¬ 
да обращения носителя. 

В частности, по команде SUM[ITEM(VOL)] [REG1] вычис¬ 
ляется сумма значений в поле количества (VOL) всех корте¬ 
жей из отношения ITEM. По команде 
DELETE [<Rn>:<yaioBHe>] 


’> Операция сложения с операндом, вычитания операнда или замены на 
операнд. — Прим, перев. 
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исключаются все кортежи, удовлетворяющие заданному усло¬ 
вию, т. е. разряд флага удаления этих записей устанавливается 
в 1. Эта команда выполняется за один период обращения но¬ 
сителя. По команде 

INSERT (n) [<Rn> : <список ячеек)] [(адрес)] 

кортежи, расположенные в ведущей машине по указанному ад¬ 
ресу, добавляются к хранимым в базе данных кортежам ука¬ 
занного отношения. Если содержимое поля «список ячеек» оп¬ 
ределено, то кортежи помещаются только в указанные ячейки. 
Время выполнения равно одному периоду обращения носителя, 
если в ячейках, которые содержат <Rn>, имеется свободное 
место. В противном случае система назначает дополнительную 
ячейку и форматизирует ее. При этом время выполнения оказы¬ 
вается равным двум периодам обращения носителя. По команде 
DESTROY[<Rn> : (список ячеек)] 

из памяти удаляется все отношение, если содержимое поля 
«список ячеек» не определено; иначе удаляются все кортежи 
данного отношения только из указанных ячеек. Освободившие¬ 
ся ячейки могут быть использованы для хранения данных дру¬ 
гих отношений. По команде 

CREATE [<Rn>:<cnHCOK ячеек)] [(адрес)] 

для заданного отношения форматизируются указанные ячейки. 
По указываемому операндом этой команды адресу содержи¬ 
мое поля «адрес» указывает местоположение в ведущей маши¬ 
не информации об именах и размерах доменов в кортежах от¬ 
ношения (Rn>. По команде 

COLGRBG [(список отношений)и/или(список ячеек)] 

выполняется „сбор мусора” в указанных отношениях или ячей¬ 
ках. Сохраняемые записи смещаются к началу циркулирующего 
носителя на место записей, отмеченных флагом удаления. По 
команде 

SPACE-COUNT[(Rn):(cnHCOK ячеек)] [(регистр)] 

выполняется подсчет свободных позиций данного отношения по 
всем или только по указанным ячейкам. Результат загружается 
в заданный регистр. 

По команде 

ВС (метка),(условие перехода) 

осуществляется передача управления команде с указанной мет- 
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кой, если выполнено условие перехода. Последнее может иметь 
следующую форму записи: 


1. <регистрХопер. сравненняХконстанта) 

2. < регистр Хопер. сравненияХрегистр> 

3. TEST«Rn>:<MapKep условие)) 


Время выполнения этой команды менее одного периода об¬ 
ращения носителя. Например, по команде ВС LOOP, REG2 = 0 
управление передается команде с меткой LOOP в случае, если 
содержимое регистра REG2 равно нулю. 

Команда ВС используется для организации циклов в RAP - 
программах, что, в частности, необходимо для выполнения опе¬ 
раций проектирования. Команды 


INSERT-REG 

DECREMENT-REG 

INCREMENT-REG 

RADD 

RSUB 

RMUL 

RDIV 


<список регистров>][<список констант)] 
(регистр)] 

(регистр)] 

<регистр)|Г<операнд>] 

<регистр)1[<операнд>] 

<регистр>1[(операнд>] 

(регистр)][(операнд>] 


выполняют операции записи, уменьшения, увеличения, сложе¬ 
ния, вычитания, умножения и деления над содержимым одно¬ 
го или неснольких регистров. Содержимое поля «операнд» ис¬ 
пользуется как указатель регистра или константы. 

Команда EOQ завершает выполнение RAP -программы. 


ПРИМЕРЫ ПРОГРАММ 

Для иллюстрации рассмотрим три примера RAP -программы. 
Первая программа исключает из отношения ЕМР записи о всех 
сотрудниках, работающих в отделе Джонса (J. Jones). Эта 
программа выглядит следующим образом 1 *: 

SAVE [ЕМР (MGR) :ЕМР. NAME = 'J.JONES'][REGO] 

DELETE [ЕМР: EMP.MGR = REGO] 

EOQ 

Время выполнения программы составляет величину немного 
более двух периодов (плюс в среднем еще половина периода 
вследствие асинхронности начала выполнения программы по 
отношению к текущему положению вращающегося носителя). 
Вторая RAP -программа предназначена для подсчета коли- 


*> Программа может состоять из двух команд: DELETE [EMP:EMP.MGR= 
='J. Jones'] и EOQ. Заметим также, что команда SAVE использована в необъ¬ 
явленном ранее варианте: с пропуском значения п. Автор ориентируется на 
версию RAP, в которой в SAVE по умолчанию п=1. — Прим, перев. 
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чества видов товарной продукции и общего объема товаров, 
проданных отделом, в котором служит Смит (С. Smith): 


1. SELECT 

2. CROSS-SELECT 


3. COUNT 

4. SUM 

5. READ-REG 

6. SELECT 

7. SELECT 

8. EOQ 


MARK (A) [EMP:EMP.NAME='C.SMITH'] 
MARK(A) [ITEM:DEPT=EMP.DEPT] 
[EMP:MKED(A)] 

[ITEM:MKED(A)][REG1] 

[ITEM (VOL) :MKED (A) ][REG2] 
[REG1,REG2][BUF] 

RESET (A) [ITEM] 

RESET(A)[EMP] 


По команде 1 для служащего Смита маркируется кортеж 
ЕМР. По команде 2 маркируются все кортежи ITEM, относя¬ 
щиеся к отделу, в котором работает Смит. С помощью команд 
3 и 4 подсчитывается количество видов маркированной товар¬ 
ной продукции и общий объем последней; результаты разме¬ 
щаются в регистрах 1 и 2. По команде 5 эти данные переписы¬ 
ваются в область BUF оперативной памяти ведущей машины. 
Последние две команды SELECT устанавливают в нулевое 
положение все использованные маркерные разряды. 

В третьей из рассматриваемых RAP -программ выполняются 
операции проектирования и условного перехода. Пусть требует¬ 
ся подсчитать число отделов, в которых имеются сотрудники, 
заработок которых превышает 30 000 долл. Воспользоваться 
одной лишь командой COUNT не представляется возможным, 
поскольку не исключены случаи, когда в каком-либо одном или 
нескольких отделах окажется более чем по одному сотруднику, 
удовлетворяющему указанному критерию отбора; нам же тре¬ 
буется подсчитать лишь количество отделов. Поставленная за¬ 
дача решается с помощью следующей RAP -программы: 


1. SELECT MARK(AB) 

2. LOOP GET-FIRST-MARK MARK (С) 

3. SELECT RESET (ABC) 

4. BC 

5. COUNT 

6. EOQ 


[EMP:EMP.SALARY>30000] 
[EMP:EMP.DEPT= 
EMP.DEPT][MKED (B) ] 
[EMP.EMP.MKED (C) ] 
A.TEST (EMP:MKED (B)) 
[EMP:EMPMKED(A)][REG1] 


В целях конкретизации анализа работы данной программы 
предположим, что первая команда SELECT «маркирует» слу¬ 
жащих Смита и Зиска из 14-го отдела, Хилса, Милса и Уилса — 
из 19-го отдела и Уайта — из 20-го отдела. При первом выпол¬ 
нении команды GET-FIRST-MARK будет обнаружен один из 
пяти упомянутых маркированных кортежей. Предположим, что 
первым окажется кортеж, соответствующий служащему Смиту. 
В результате выполнения этой комайды станут С-маркирован- 
ными все остальные В-маркированные кортежи того же отдела, 



сотрудником которого является Смит; при этом В-маркер Сми¬ 
та будет сброшен. Следующая команда SELECT выполнит 
сброс маркеров АВС во всех С-маркированных кортежах (от¬ 
носящихся к служащему Зиску). 

При выполнении команды ВС будет обнаружено, что суще¬ 
ствуют также В-маркированные кортежи. Поэтому произойдет 
повторение указанной последовательности команд. Пусть на 
этот раз команда GET-FIRST-MARK найдет служащего Милса, 
выполнит С-маркирование кортежа, соответствующего служа¬ 
щим Хилсу и Уилсу, и осуществит сброс В-маркера кортежа 
Милса. Следующая команда SELECT произведет сброс маркер¬ 
ных разрядов АВС кортежей, относящихся к служащим Хилса 
и Уилса. И опять команда ВС найдет В-маркер (только в кор¬ 
теже В), после чего будет повторено выполнение указанной по¬ 
следовательности команд. Теперь команда GET-FIRST-MARK 
установит в 0 В-маркер кортежа Уайта, однако больше не об¬ 
наруживаются кортежи, нуждающиеся в маркировании. После¬ 
дующая команда SELECT не выявит кортежей, удовлетворяю¬ 
щих условию. Команда ВС не обнаруживает В-маркированных 
кортежей. Команда COUNT вычислит требуемую величину, ока¬ 
зывающуюся в данном случае равной 3 (Смит, Миле и Уайт), 
и загрузит ее в регистр 1. 

ЭФФЕКТИВНОСТЬ ПРОЦЕССОРА RAP 

Наиболее очевидным преимуществом архитектуры реляционно¬ 
го ассоциативного процессора перед традиционными принципа¬ 
ми организации БД с адресацией по положению является его 
быстродействие, обусловленное следующими тремя факторами; 

1. Параллельное выполнение операций. Естественно, что 
большие отношения (файлы) охватывают значительное число 
ячеек, которые допускают одновременное выполнение большин¬ 
ства операций поиска и модификации (обновления) информа¬ 
ции. В традиционных же системах с обратными списками или 
индексами все операции выполняются последовательно. На¬ 
пример, для отбора данных по значениям определенного доме¬ 
на индекс считывается в оперативную память процессора, осу¬ 
ществляется последовательный поиск и затем каждая требуе¬ 
мая запись последовательно считывается. 

2. Обновление данных на месте. Поскольку процессор RAP 
функционирует согласно принципу ассоциативной обработки, 
обновление данных сводится к замене соответствующего корте¬ 
жа. В то же время в традиционных БД, базирующихся на прин¬ 
ципе индексирования, изменения необходимо вносить как в сам 
кортеж, так и в индекс. Если для изображенной на рис. 20.4 БД 
сотрудников торговой фирмы индексы организованы для всех 
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доменов файла сотрудников, то добавление нового кортежа в 
этот файл должно сопровождаться изменением четырех индек¬ 
сов. 

3. Сокращение числа пересылок данных. Объемы данных, 
пересылаемых между процессором ведущей машины и па¬ 
мятью (БД), в процессоре RAP на несколько порядков меньше, 
чем в традиционных системах. Наиболее разительно это прояв¬ 
ляется в выполнении логических операций и при модификации 
данных. Если требуется в файле сотрудников увеличить дли¬ 
тельность отпуска (значения соответствующего домена) на од¬ 
ну неделю, то из ведущей машины в процессор RAP должны 
быть переданы только две команды, а в обратном направле¬ 
нии — признак конца выполнения. В обычных же СУБД каж¬ 
дая запись (кортеж) должна быть считана в память процессо¬ 
ра, изменена и записана на носитель. При требовании подсче¬ 
та количества записей, удовлетворяющих некоторому условию, 
в процессор RAP пересылается только одна команда. А в тра¬ 
диционных системах требуется пересылка в ведущую машину 
всего индекса. 

С использованием методов численного моделирования [5] 
было проведено сравнение скорости выполнения операций в 
процессоре RAP и в обычных системах. В табл. 20.1 даны отно¬ 
сительные значения скорости выполнения основных операций 
в процессоре RAP по сравнению с обычными системами. Колон¬ 
ки таблицы соответствуют случаям, когда в БД находятся соот¬ 
ветственно 500 или 3000 кортежей, удовлетворяющих заданно¬ 
му критерию отбора. При расчетах предполагалось, что память 
системы RAP состоит из 100 ячеек по 1000 кортежей в каждой. 
Сравнение проведено с БД традиционной организации, имею¬ 
щей память на дисках с инвертированными списками. 

Таблица 20.1. Относительные значения скорости выполнения операций 
в системе RAP по сравнению с традиционными системами 



Скорость (в OTF 

Г ™ * при m ,u. 

Операция 

честве кортежей, удовлетворяю¬ 
щих критерию отбора, равном 

500 

3000 


Поиск по простому условию 

12 

55 

Поиск по сложному условию 

18 

45 

Простая модификация 

1000 

5000 

Сложная модификация 

300 

1600 

Простой отбор/подсчет/выдача 

35 

60 

Сложный отбор/подсчет/выдача 

20 

35 

Присоединение 

0,1-1 

0,5-4 
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«Простые» операции в табл. 20.1—операции с одним усло¬ 
вием типа равенства. «Сложные» операции предусматривают 
проверку десяти простых условий. Простая операция типа от¬ 
бор/подсчет/выдача может использоваться, например, при вы¬ 
полнении запроса: «Выдать список сотрудников, зарабатываю¬ 
щих больше вице-президента компании». Отношение скоростей 
выполнения операции присоединения зависит от того, реализу¬ 
ется ли в системе RAP с целью сокращения времени выполне¬ 
ния операции присоединения предварительная операция проек¬ 
тирования. Поэтому в последней строке таблицы данные при¬ 
ведены в виде диапазонов значений этой величины (см. упр. 20.7 
и 20.8 в конце главы). 

ВЕРСИЯ RAP.3 

В новой версии RAP сняты некоторые ограничения, присущие 
RAP.2. С целью повышения скорости обработки применены осо¬ 
бый способ хранения данных и новый принцип организации 
ячейки памяти [9]. Для повышения пропускной способности 
используется последовательный по словам способ доступа к дан¬ 
ным на вращающемся носителе вместо последовательного по 
разрядам. Кроме того, в пределах каждой ячейки организовано 
несколько секций, что позволяет обрабатывать несколько корте¬ 
жей в ячейке одновременно. 

В известной реализации RAP.3 ячейка состоит из четырех 
секций. Анализ и модификация содержимого кортежей на вра¬ 
щающемся носителе могут выполняться независимо в каждой 
из секций. Секции реализованы на 16-разрядных микропроцес¬ 
сорах серии 8086. В результате построение ячейки процессо¬ 
ра RAP сводится не столько к проектированию логических 
схем, сколько к созданию программных модулей микропроцес¬ 
соров 8086. Благодаря этому, во-первых, уменьшается число 
компонентов: несмотря на то что каждая ячейка состоит из че¬ 
тырех секций, общее количество модулей в системе RAP.3 со¬ 
ставляет только третью часть количества модулей RAP.2. Во- 
вторых, оказывается возможным выполнять некоторые более 
«гибкие» операции. Синхронизация работы ячейки во времени 
такова, что пока в одну секцию загружается кортеж, в двух 
других секциях выполняется совместная обработка двух кор¬ 
тежей, а в четвертой секции может выполняться также опера¬ 
ция записи кортежа на вращающийся носитель. 

Процессор RAP.3 обладает лучшими эксплуатационными 
характеристиками. В частности, количество маркерных разря¬ 
дов в кортеже увеличено до 16. В домены можно записывать 
символьную информацию. Домены могут быть произвольной 
длины. Единственным условием является следующее: общая 
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длина кортежа не должна превышать 1024 байт. Включены 
команды сравнения доменов. 

В процессоре RAP.3 увеличена скорость выполнения опера¬ 
ции объединения (CROSS-SELECT), выполнявшаяся в RAP.2 
относительно медленно. Это оказалось возможным благодаря 
двум нововведениям. Во-первых, роль вращающейся памяти в 
RAP.3 выполняет память на ЦМД. Это позволяет останавли¬ 
вать и возобновлять процессы цикличного обмена в любой мо¬ 
мент времени и, следовательно, более эффективно выполнять 
команду CROSS^SELECT. Во-вторых, скорость выполнения 
команды CROSS-SELECT в процессоре RAP.2 ограничивалась 
допустимыми малыми значениями параметра к (числом доме¬ 
нов, значения которых из взятого за основу отношения учиты¬ 
вались при выполнении сравнений по CROSS-SELECT). Для 
процессора RAP. 2 эта величина равнялась 3. В процессоре 
RAP.3 вместо ограничения на величину к наложено ограниче¬ 
ние на общую длину сравниваемых данных. Эта длина не долж¬ 
на превышать 800 байт (например, 400 2-байтовых полей). 

ИСПОЛЬЗОВАНИЕ ПРОЦЕССОРА RAP 
В БОЛЬШИХ СУБД 

Подсчитано, что наиболее рационально использовать процессор 
RAP при объеме данных ІО 8 — ІО 9 бит. Поскольку многие БД 
являются хранилищем большого объема информации, была 
предложена модификация RAP с использованием принципов 
виртуальной памяти [3, 6]. 

В этой новой разработке все данные хранятся в основной 
памяти неассоциативного типа. Каждая ячейка процессора RAP 
располагает двумя вращающимися носителями. В любой дан¬ 
ный момент времени один из них выполняет функции активной 
памяти, а другой — буфера. Как следует из рис. 20.5, оба носи¬ 
теля связаны с ячейкой через переключатель. В то время как 
один из них подсоединен к ячейке, другой подключается к про¬ 
цессору (контроллеру) ввода-вывода, посредством которого 
выполняется обмен данными с основной памятью. 

Один из вариантов функционирования системы может за¬ 
ключаться в следующем. Закончив формирование очередной 
RAP -программы, ведущая машина определяет, содержатся ли 
необходимые отношения в памяти процессора RAP. Если их 
в памяти нет, то процессор ввода-вывода выполняет пересылку 
этих отношений (опережающую запись «страницами») из ос¬ 
новной памяти в ячейки процессора RAP. В это время система 
RAP может продолжать обработку какой-либо другой програм¬ 
мы. Алгоритм перелистывания страниц памяти в первую оче¬ 
редь может выполнять поиск тех ячеек вращающихся носите- 
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лей, содержимое которых 
не обновлялось и к кото¬ 
рым в соответствии с теку¬ 
щим состоянием системной 
очереди RAP не запланиро¬ 
ван доступ обрабатываю¬ 
щих программ. Если имею¬ 
щиеся в распоряжении но¬ 
сители ячеек содержат 
только модифицированные 
отношения, то они сначала 
постранично считываются 
в основную память. По за¬ 
вершении пересылки данных 
в процессор RAP пересыла¬ 
ются программа и информа¬ 
ция о конкретной паре вра¬ 
щающихся носителей, которые должны быть переключены на 
альтернативный режим работы (так называемый свопинг ): ак¬ 
тивный носитель превращен в буферный, а буферный в актив¬ 
ный. При использовании другого варианта функционирования 
управление пересылкой данных может быть возложено не на 
ведущую машину, а на процессор ввода-вывода системы RAP. 

В основу метода перелистывания страниц положено правдо¬ 
подобное, хотя и строго не проверенное предположение о том, 
что поток запросов к БД отличается свойством «локальности 
ссылок» подобно аналогичному свойству потока запроса прог¬ 
рамм к частям оперативной памяти, наблюдаемому в системах 
с виртуальной организацией памяти. Можно высказать следую¬ 
щие соображения в пользу такого интуитивного решения. По 
мере приближения некоторых критических моментов времени 
(например, запланированного времени отправления самолета) 
заметно возрастает интенсивность работы с определенными от¬ 
ношениями (в данном случае — с отношением, содержащим ин¬ 
формацию об этом рейсе). Это вызывает эффект повышенной 
локальности запросов к БД. Аналогичным образом использова¬ 
ние интерактивных языков запросов благоприятствует режиму 
последовательных просмотров БД (поиску подходящих данных 
на основе планомерной модификации запроса). В этом случае 
также на короткие периоды времени повышается частота обра¬ 
щения к отдельным группам отношений БД. Наконец, для про¬ 
грамм пакетной обработки и для программ — генераторов отче¬ 
тов характерны многократные повторные обращения к одной и 
той же группе отношений БД, что тоже приводит к повышен¬ 
ной локальности ссылок. 



Рис. 20.5. Ячейка RAP, предназначенная 
для реализации перелистывания 
страниц в памяти. 
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ДОСТОИНСТВА ПРОЦЕССОРА RAP 

Выше был отмечен ряд достоинств процессора RAP и, в част¬ 
ности, большая скорость выполнения операций. Отметим еще 
некоторые важные достоинства процессора RAP и аналогичных 
систем ассоциативной памяти. Одно из них заключается в том, 
что для БД, выполненной по схеме RAP, требуется намного 
меньший объем памяти, чем при ее реализации по традицион¬ 
ной (неассоциативной) схеме. Дело в том, что в обычной систе¬ 
ме в целях сокращения среднего времени доступа к данным 
требуется применение индексов или обратных списков. Для от¬ 
дельного файла (отношения) со 100 полями или доменами мо¬ 
жет оказаться необходимой организация индексов для 10 или 
большего числа полей. Когда индексов много, требуемая для их 
хранения память может оказаться сравнимой с основной па¬ 
мятью БД или даже превысить ее. 

В связи со сложностью организации системы индексов в 
традиционных СУБД при планировании структуры БД проявля¬ 
ется еще одно преимущество процессора RAP. Применительно 
к традиционным системам представляются практически нецеле¬ 
сообразными организация и ведение индексов для всех полей 
записей БД. Во-первых, это привело бы к очень большому 
расходу памяти. Во-вторых, если и создать такую систему ин¬ 
дексов, то операции обновления существующих записей и до¬ 
бавления новых записей будут выполняться медленно, посколь¬ 
ку с поступлением каждой новой записи требуется изменение 
каждого индекса. Поэтому проектировщик БД стоит перед 
сложной проблемой выбора подмножества полей, к которым 
следует применить индексирование (т. е. проблемой указания 
полей, по которым будут выполняться операции поиска). Прог¬ 
ноз проектировщика может оказаться неудачным (например, 
вначале предполагалось, что не потребуется выполнять поиск 
записей в файле сотрудников по размеру заработной платы, а 
позднее такая необходимость возникла). В связи с использова¬ 
нием процессора RAP подобные проблемы не встают, посколь¬ 
ку адресация выполняется ассоциативным образом. 

Другим достоинством процессора RAP являются большие 
возможности к расширению БД. Допустим, что возникла не¬ 
обходимость в увеличении объема БД на 50% (например, 
вследствие слияния корпораций) при одновременном сохране¬ 
нии временных характеристик доступа к данным на прежнем 
уровне. В СУБД со средствами индексирования время доступа 
пропорционально (но нелинейно) числу записей, и для обеспе¬ 
чения прежнего времени доступа потребовался бы процессор 
с более высокой скоростью выполнения операций. Однако та¬ 
кое решение может оказаться неприемлемым, например, вслед- 
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ствие уникальных характеристик имеющегося в данный момент 
процессора, или из-за того, что этот процессор является наибо¬ 
лее высокопроизводительным в своем классе, или в связи с тем, 
что переход к процессору с более высоким быстродействием 
сопровождается недопустимо резким увеличением отношения 
стоимость/производительность. В системах же типа RAP вы¬ 
числительная мощность растет по мере наращивания памяти 
в процессе подключения дополнительных секций. 

Из других достоинств этих систем можно отметить мень¬ 
шую сложность программного обеспечения СУБД в ведущей 
машине и облегченный режим работы последней. 

УПРАЖНЕНИЯ 

20.1. Для БД, структура которой изображена на рис. 20.4, составьте 
RAP -программу, в соответствии с которой производится увеличение на 
100 долл, размера годового оклада (SAL) всех сотрудников отделов (DEPT) 
с наивысшим показателем количества изделий (VOL) по одному или несколь¬ 
ким видам продукции (PARTNUM). Эта операция не должна выполняться 
для сотрудников с SAL >20 000. 

20.2. Рассчитайте ожидаемое время выполнения программы, описанной 
в предыдущем упражнении в предположении, что период просмотра ассо¬ 
циативной памяти (период оборота вращающегося носителя) равен 20 мс, 
число сотрудников в отделах, удовлетворяющих поставленному условию, рав¬ 
но 8, a k=5. 

20.3. Наиболее очевидное преимущество системы RAP по сравнению с 
традиционными СУБД заключается в возможности параллельного выполнения 
операций. Назовите другие важные показатели подобных систем, определяю¬ 
щие их высокую производительность. 

20.4. Почему относительные скорости выполнения операций процессора 
RAP по сравнению с традиционными системами меньше для «сложных» опе¬ 
раций (см. табл. 20.1)? 

20.5. Пусть БД, обслуживаемая системой типа RAP, представлена тремя 
отношениями: АДРЕСА, АБОНЕНТЫ и ТАРИФЫ. В отношение АДРЕСА 
входят три домена: ГОРОД, КОЛИЧАБ (количество абонентов) и КОДРАЙ- 
ОНА. В отношении АБОНЕНТЫ шесть доменов: РАСЧНОМ (расчетный но¬ 
мер), КО ДРАНО НА, НОМЕРАБ (номер телефона абонента), КО Л АП (коли¬ 
чество телефонных аппаратов), КАТЕГОР (категория абонента), МПЛАТА 
(месячная абонентная плата). В отношении ТАРИФЫ два домена: КАТЕГОР 
(категория) и МИНПЛАТА (минимальная месячная абонентная плата). 

Требуется составить RAP -программу для подсчета суммарной месячной 
абонентной платы по всем абонентам категории Q района Майами, имеющим 
более одного телефонного аппарата и месячную плату, равную ее минималь¬ 
ному значению для указанной категории. 

20.6. Предположим БД, описанная в предыдущем упражнении, характе¬ 
ризуется следующими числовыми параметрами: число записей (кортежей) в 
отношении АДРЕСА равно 1000, в отношении АБОНЕНТЫ равно 1 000 000, 
а в отношении ТАРИФЫ составляет 13. Кроме того, положим k=5 и будем 
считать, что все абоненты Майами относятся к одному району. Требуется 
определить, за какое количество циклических просмотров БД может быть 
обработан сформулированный в предыдущем упражнении запрос. 

20.7. Допустим, что требуется выполнить совместную обработку отноше¬ 
ний, изображенных на рис. 20.4, для маркирования кортежей с информацией 
о всех служащих всех подразделений, в которых объем проданной продукция 
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(VOL) хотя бы одного из выпускаемых видов изделий меньше 1000. Как вос¬ 
пользоваться командой GET-FIRST-MARK для уменьшения времени выпол¬ 
нения при использовании команды CROSS-SELECT? 

20.8. В условиях предыдущего примера предположим дополнительно, что 
количество записей в отношении ITEM, удовлетворяющих сформулированному 
требованию, равно 200. Пусть они относятся к 10 различным подразделени¬ 
ям, а все отношение ITEM распределено по двум секциям процессора RAP. 
Насколько сократится время обработки при использовании операции проек¬ 
тирования по сравнению с использованием команды совместной обработки 
CROSS-SELECT? 
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ГЛАВА 21 

ДРУГИЕ МАШИНЫ БАЗЫ ДАННЫХ 

Реляционный ассоциативный процессор (RAP) являет собой 
один из возможных примеров применения принципа ассоциа¬ 
тивности для обработки информации, хранимой в БД. В этой 
главе рассматриваются две вычислительные машины, реализу¬ 
ющие этот принцип и предназначенные для использования в ка¬ 
честве специализированных машин базы данных. 

ПРОЦЕССОР CASSM 

Процессор CASSM (context addressed segment sequential me¬ 
mory), или процессор с контекстуально адресуемой сегментиро¬ 
ванной последовательной памятью, имеет много общего с про¬ 
цессором RAP. Программное моделирование процессора 
CASSM было осуществлено в Университете шт. Флорида. К на¬ 
стоящему времени выполнена и аппаратная реализация одной 
ячейки этой системы. Ниже перечисляются основные характе¬ 
ристики подобия и различия процессоров CASSM и RAP. 

1. Принципы организации систем CASSM и RAP почти пол¬ 
ностью идентичны. Процессор CASSM состоит из контроллера 
и набора ячеек, каждая из которых имеет запоминающее уст¬ 
ройство в виде вращающегося носителя. 

2. Хранимые в процессоре CASSM данные организованы 
в иерархические (древоподобные) структуры. 

3. Все данные хранятся вместе со своими описаниями (т. е. 
имеют теги). Записи одного и того же файла не обязательно 
имеют одну и ту же длину или формат. 

4. Команды в процессоре CASSM поступают непосредствен¬ 
но из БД, а не из обслуживающей машины (ведущей ЭВМ). 

ОРГАНИЗАЦИЯ ДАННЫХ 
В ПРОЦЕССОРЕ CASSM 

Логическая структура БД в процессоре CASSM может быть 
представлена одним или несколькими иерархическими деревья¬ 
ми связи данных. В качестве примера рассмотрим БД грузовых 
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Рис. 21.1. Логическая структура файла в процессоре CASSM. 

СН — станция назначения, М — местонахождение, П — получатель, 

ГВП — гарантируемое время прибытия по расписанию, ВПР — время прибытия 
по расписанию. 

железнодорожных перевозок. Пусть, в частности, один из фай¬ 
лов БД содержит информацию о составах и грузах, находящих¬ 
ся в пути. Каждый конкретный поезд в БД представляется от¬ 
дельной записью, которая содержит следующие данные: номер 
железнодорожного состава, станцию назначения, дату и время 
прибытия по расписанию, текущее местонахождение и инфор¬ 
мацию маршрутных листов отдельных вагонов данного соста¬ 
ва. Последняя может состоять из инвентарного номера вагона, 
идентификатора получателя и гарантируемой даты прибытия. 
Логическая структура такого файла в CASSM может быть 
представлена в форме, показанной jia рис. 21.1 1 >. 

На вращающихся носителях памяти процессора CASSM дан¬ 
ные представлены отдельными словами, состоящими из 40 дво¬ 
ичных разрядов. Форма доступа — последовательная по раз¬ 
рядам. Два разряда из 40 используются для обеспечения «внут- 


*> Несущественное отличие структуры, изображенной на рис. 21.1, и соот¬ 
ветствующей ей структуры записей в памяти от приведенного здесь описания 
заключается в отсутствии информации о дате прибытия по расписанию.— 
Прим, перев. 
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Таблица 21.1. Типы слов, используемых в процессоре CASSM 


Тип слова 

1 Шифр типа 

Тег 

Состояние 

Данные (32 двоичных 
разряда) 

Ограничитель 

Е> 

000 

м, н,с 

ИМЯ-УРОВЕНЬ, 





BSTK, S, Q 

Имя-значение 

N 

001 

м, н,с 

ИМЯ, ЗНАЧЕНИЕ 

Указатель 

Р 

010 

м,н,с 

ИМЯ, УКАЗАТЕЛЬ 

Строка 

S 

011 

М.Н.С 

4 символа 

Команда 

I 

100 

ТР, А 

Команда или литерал 

Операнд 

О 

101 

LN.F 

32-битовое значение 

Защита доступа 

L 

по 



Данные, подлежа¬ 

Е 

111 

WD 


щие исключению 











Примечания. 

М — бит совпадения, 

Н — бит сохранения, 

С — бит маркирования выводимых данных, 

S — бит выделения данных, которые могут отмечаться в результате 
рации поиска, 

Q — бит промежуточного маркирования данных, 

А — бит активации. 

F — флаг конца списка, 

ИМЯ —имя единицы информации предметной области (16 разрядов), 

УРОВЕНЬ — порядковый номер уровня в иерархии (8 разрядов), 

BSTK — стек результатов операции поиска (6 разрядов), 

ЗНАЧЕНИЕ — значение в двоичной форме (16 разрядов), 

УКАЗАТЕЛЬ — номер записи, 

ТР — указатель команды (слово является командой или литералом), 

LN — порядковый номер операнда в стеке или очереди (2 разряда), 

WD — указатель конца файла, временного характера данных или «мусора: 


ренних потребностей» ячейки, три разряда — для записи тега 
данных, три других разряда являются индикаторами состояния, 
а в оставшихся 32 разрядах обычно содержатся данные. Допус¬ 
кается использование слов восьми типов (см. табл. 21.1). 

Для определения каждого узла каждого дерева БД исполь¬ 
зуется слово ограничитель. Оно определяет имя узла в БД (на¬ 
пример, «железнодорожный состав») и его уровень в иерархии. 
Основные операции системы CASSM выполняются при исполь¬ 
зовании следующих разрядов слова: BSTK, S и Q. Группа раз¬ 
рядов BSTK используется подобно маркерным разрядам корте¬ 
жей в системе RAP, хотя и представляет собой память стеково¬ 
го типа. Разряд Q является индикатором, определяющим 
данные, подлежащие обработке в предстоящей поисковой опе¬ 
рации. Перед началом этой операции CASSM -программа уста¬ 
навливает значение этого индикатора. В частности, производит¬ 
ся предварительная установка в 1 разряда Q для намеченных 
к обработке узлов БД. 

Функциям разряда S в ограничителе нет аналога в системе 
RAP. Реляционный принцип организации данных в RAP одно- 
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значно определяет, что по завершении поиска подлежит марки¬ 
ровке (а именно, кортежи, удовлетворяющие заданному усло¬ 
вию). В случае же иерархической организации данных, приня¬ 
той в CASSM, ответ на подобный вопрос не столь очевиден. 
Пусть, например, выполняется поиск вагона с инвентарным но¬ 
мером J6796. При этом остается неясным, следует ли отметить 
запись о самом вагоне, о поезде, в состав которого он входит, 
или всю группу поездов. Двоичная единица в разряде S, уста¬ 
навливаемая до начала поиска, используется для указания, 
какой именно узел (узлы) подлежит маркировке после успеш¬ 
ного завершения поиска. Например, если имеется необходи¬ 
мость отметить поезд, в состав которого входит вагон J6796, то 
следует установить в 1 значение разряда S во всех узлах ти¬ 
па 1, ПОЕЗД. 

Слово имя-значение используется для определения каждого 
поля в каждом узле структуры БД. В этом слове содержится 
имя поля (в системе CASSM имя поля включается в слова 
«ограничитель» и «имя-значение», подобно тому как имена по¬ 
лей включаются в записи системы RAP) и его значение (в ви¬ 
де дополнительного двоичного 16-разрядного кода). Благодаря 
этому информация о каждом поле в БД является самоопреде- 
ляемой. Поэтому система допускает произвольную последова¬ 
тельность записей данных об отдельных полях или узлах БД, 
отсутствие отдельных полей в однотипных записях и многократ¬ 
ное повторение поля в одной и той же записи. 

Слово указатель применяется для различных целей. Его 
можно использовать в тех случаях, где допустимо применение 
слова «имя-значение» при условии, что вместо значения исполь¬ 
зуется адрес или указатель. Слово «указатель» служит для 
представления полей с нечисловым содержимым, а именно по¬ 
лей, в которых находится одно или несколько слов типа «стро¬ 
ка»; при этом слово «указатель» определяет отдельное поле и 
задает адрес первого слова «строка». Словом «указатель» мож¬ 
но пользоваться также в целях уменьшения избыточности (в 
частности, если разные поля имеют одно и то же нечисловое 
содержимое, то можно ограничиться одним таким полем, обра¬ 
щаясь к нему по мере необходимости посредством слова «ука¬ 
затель»). С помощью слова «указатель» иерархическое пред¬ 
ставление данных переводится в сетевое представление или 
ориентированный граф. 

Иерархические структуры данных записываются в запоми¬ 
нающие устройства ячеек системы CASSM в соответствии с 
принципом так называемой линейной развертки: сверху вниз и 
слева направо. Иллюстрацией сказанному может служить 
представленное на рис. 21.2 содержимое слов «ограничитель» 
и «имя-значение». В этих словах указано содержимое только 
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Рис. 21,2. Слово «ограничитель» и слово «имя-значение». 


тех полей, которые необходимы для дальнейших рассуждений. 
Разряд С (Collection) полей используется для маркировки той 
информации в БД, которая будет вводиться в ведущую ма¬ 
шину. 

В табл. 21.2 показана физическая структура записей, соот¬ 
ветствующая иерархической БД, изображенной на рис. 21.1. 
Для простоты приведено только несколько слов структуры и 
игнорируется возможность хранения в словах «имя-значение» 
нечисловых данных. 


НАБОР КОМАНД СИСТЕМЫ CASSM 

Набор, команд, относящихся к процессору CASSM, не является 
обширным, однако многие команды позволяют реализовать 
большое разнообразие операций того или иного типа посредст¬ 
вом задания в команде необязательных параметров. К четырем 
основным командам обработки данных относятся следующие: 
маркировка ограничителя (DMK), поиск данных по некоторому 
условию (QSR), определение местоположения данных (FND) 
и определение состояния данных (FNS). 

Команда DMK используется для просмотра записей БД 
с целью: 

1) маркировки тех записей, которые предназначаются для 
следующего поиска (т. е. целью просмотра является установка 
в 1 разрядов Q в части записей БД), или 

2) маркировки тех узлов (ограничителей), в которые долж¬ 
ны быть помещены результаты последующего поиска (т. е. 
целью просмотра является установка разрядов S в соответст¬ 
вующих записях БД). 

Так, команда DMK W 1, TRAIN выделяет из всех записей 
БД(признак W) ограничители на первом уровне с именем 
TRAIN и устанавливает в 1 их разряды S и Q. Команда 
DMK D Q*,* устанавливает в 1 только разряд Q во всех узлах 
всех уровней (*) с любыми именами (*), если эти узлы подчи¬ 
нены (признак D — descendent) хотя бы одному узлу с уже 
установленным в 1 разрядом Q. 
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Таблица 21.2. Пример линейного представления иерархической структуры БД 
в процессоре 


Структура записей 


С 

Тег 

Имя 

Значение 

Уровень 

BSTK 

s 

Q 

0 

D 

поезда 


0 

000000 

0 

0 

0 

D 

поезд 


1 

000000 

0 

0 

0 

N 

инвентарный номер 

422 






N 

станция назначе- 








ния 

Utica 






N 

ожидаемое время 








прибытия 

2000 






N 

местонахождение 

Milo 





0 

D 

вагоны 


2 

000000 

0 

0 

0 

D 

вагон 


3 

000000 

0 

0 

0 

N 

инвентарный номер 

J2223 





0 

N 

идентификатор по- 








лучателя 

Xerox4 





0 

N 

гарантированная 








дата 

0930 





0 

D 

вагон 


3 

000000 

0 

0 

0 

N 

инвентарный номер 

J6796 





0 

N 

идентификатор по- 








лучателя 

Xerox4 





0 


гарантированная 








дата 

j 1002 





0 

D 

вагон 


3 

000000 

0 

0 

0 

N 

инвентарный номер 

T3499 





0 

N 

идентификатор по¬ 








лучателя 

Shell 





0 

N 

гарантированная 








дата 

0928 





0 

D 

поезд 


1 

000000 

0 

0 

0 

N 

инвентарный номер 

637 





0 

N 

станция назначе¬ 








ния 

Chicago 





о 

N 

ожидаемое время 








прибытия 

1130 





0 

N 

местонахождение 

Gary 





0 

D 

вагоны 


2 

000000 

0 

0 

о 

D 

вагон 


3 

000000 

0 

0 

о 

N 

инвентарный номер 

T0272 





о 

N 

идентификатор по¬ 








лучателя 

USAir 





о 

N 

гарантированная 








дата 

1005 






D 

вагон 


3 

000000 

0 

, о 


N 

инвентарный номер 

L8289 





» 

N 

идентификатор по¬ 








лучателя 

Lake7 






N 

гарантированная 








дата 

1005 
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Команда QSR подобна команде SELECT процессора RAP. 
Поиск проводится по всем узлам с маркером Q (т. е. разряд 
которых установлен в 1). Одной из функций команды QSR 
является выполнение логической операции ИЛИ над результа¬ 
тами обработки всех узлов поддерева с маркером Q, после чего 
определяется местоположение узлов с маркером S. (Последние 
находятся на том же или более высоком уровне иерархии.) 
Результат упомянутой операции ИЛИ может быть либо непо¬ 
средственно переслан в стек BSTK соответствующего узла с 
маркером S, либо путем выполнения логической операции И 
или ИЛИ над этим результатом и битом на вершине стека 
BSTK- В процессе поиска могут выполняться требуемые срав¬ 
нения (на равенство, на превышение и т. п.). 

Команды FND и FNS используются для модификации дан¬ 
ных и их маркировки с целью последующего вывода. Парамет¬ 
ры команд определяют условия отбора и предпринимаемые дей¬ 
ствия. Условия отбора могут учитывать состояние данных (ко¬ 
торое может быть выражено значением содержимого разря¬ 
да Q), значение бита на вершине стека BSTK или значение 
данных. Действия могут заключаться в маркировке данных для 
последующего вывода (путем установки в 1 разряда С), моди¬ 
фикации данных в указанных полях или выполнении таких 
операций над содержимым группы выделенных полей, как вы¬ 
числение суммы всех значений, количества последних, их мак¬ 
симальной или минимальной величины. 

Функционирование команд может быть проиллюстрировано 
примером запроса к БД. В частности, для БД, структура кото¬ 
рой представлена на рис. 21.1 и в табл. 21.2, запрос «Найти 
поезда, в состав которых входят вагоны с гарантированной да¬ 
той прибытия до 6 октября (1006) или гарантированной датой 
прибытия 10 октября (1010)» выполняется с использованием 
следующей последовательности команд: 

DMK W 1, train 

DMK D Q*,* 

QSR <,N;PUB;IM(gad:1006) 

QSR =,N;ORB;IM(gad:1010) 

FND В N,iden;ORS C;LDP, WDR,CP,WTC 

Первые две команды этой программы были рассмотрены 
выше. Следующая команда QSR просматривает все вершины 
дерева с установленным в 1 разрядом Q (т. е. все поезда и ва¬ 
гоны) в поисках тех из них, в которых значение слова «имя-зна¬ 
чение» с именем gad (гарантированная дата прибытия) мень¬ 
ше 1006. Результаты поиска по вершинам, подчиненным вер¬ 
шинам с маркерами S, объединяется логической операцией 
ИЛИ и затем посылаются: (операнд PUB) в стек BSTK вершин 
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с маркером S. Вторая команда QSR выделяет слова «имя-зна¬ 
чение» с именем gad и значением 1010. Результаты поиска па 
вершинам, подчиненным вершине с маркером S, объединяются 
логической операцией ИЛИ между собой и битом на вершине 
стека BSTK и замещают его (операнд ORB). 

По команде FND осуществляется поиск слов «имя-значение» 
с именем iden. Если биту на вершине стека BSTK предшеству¬ 
ющего ограничителя присвоено значение 1, то содержимое раз¬ 
ряда С замещается на результат логической операции ИЛИ 
над ним и 1 (операнд ORS). Согласно операнду LDP (load 
controller processor status word), осуществляется загрузка PSW, 
в результате чего содержимое вершин с маркерами С пересыла¬ 
ется в ведущую машину или управляющий процессор (операнд 
СР) в произвольном (с точки зрения следования слов) порядке 
(операнд WDR). При этом запрещается изменение PSW до 
окончания передачи содержимого всех С-маркированных вер¬ 
шин (операнд WTC). Функционирование процессора CASSM 
регулируется последовательностью команд и значением PSW. 

В процессоре CASSM имеются средства межфайловой мар¬ 
кировки. Эти возможности реализуются с помощью операндов 
XWR и XRW команд FND и FNS. Каждая ячейка системы 
CASSM располагает 1-разрядной памятью произвольного дос¬ 
тупа. При выполнении указанных операций для всех п ячеек — 
«участниц» операции создается общая 1-разрядная память про¬ 
извольного доступа объемом п. По команде FND с операн¬ 
дом XWR в эту память записываются значения всех данных, 
удовлетворяющих критериям отбора. При этом, если значение 
данных, представленное числом 5, удовлетворяет критериям от¬ 
бора, пятому разряду указанной памяти присваивается единич¬ 
ное значение. (Подобный режим работы предполагает предва¬ 
рительное кодирование значений в данных элементами множе¬ 
ства целых чисел 0. п.) После указанной операции в упомя¬ 

нутой памяти из 1-разрядных элементов оказываются отмечен¬ 
ными все значения данных, удовлетворяющие установленным 
критериям отбора. Теперь может быть применена коман¬ 
да FND с операндом XRW для маркировки значений данных в 
другом файле, если единичное значение присвоено тому биту 
1-разрядной памяти, который соответствует заданному значе¬ 
нию. 


ВЫПОЛНЕНИЕ CASSM -ПРОГРАММ 

Необычной характеристикой системы CASSM, составляющей 
в то же время главное отличие процессора CASSM от процес¬ 
сора RAP, является хранение команд CASSM в базе данных. 
В соответствии с табл. 21.1 команды можно рассматривать 
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как особый вид хранимой в БД информации, т. е. как одну из 
разновидностей структур данных. Программа для CASSM мо¬ 
жет быть представлена в виде дерева команд в БД, где подде¬ 
ревья (вводимые словами «ограничитель») аналогичны под¬ 
программам и блокам, вводимым служебным словом begin. 
В отличие от процессора RAP здесь команды не поступают из 
ведущей машины. В результате процессор CASSM может ис¬ 
пользоваться как автономная система, где в основе иницииро¬ 
вания команд лежат модифицирующие операции над данными. 

В соответствии с табл. 21.1 в коде каждой команды имеется 
так называемый разряд активности (разряд А). Ячейки CASSM 
^сканируют свою память, и каждая встречающаяся при этом 
^команда выполняется, если ее разряд А установлен в 1. После 
выполнения команды разряд А устанавливается в 0, т. е. сбра¬ 
сывается. Помимо рассмотренных выше команд в системе 
CASSM предусмотрена группа команд управления выполнени¬ 
ем программы. Эти команды могут активировать и дезактиви¬ 
ровать другие команды. Так, команда ACT(ACTivate) устанав¬ 
ливает в 1 разряд А в указанной группе команд. Команда DAC 
(DeACTivate) выполняет обратное действие. Команда JMP 
сбрасывает разряд А во всех командах БД, а затем устанавли¬ 
вает его в 1 в предписанном множестве команд. Команда ACS 
подобна команде ACT, но осуществляет также загрузку содер¬ 
жимого разряда S в ограничителях, предшествующих коман¬ 
дам в дереве программы, в стек BSTK этих ограничителей. 
Команда POP восстанавливает содержимое разряда S, извле¬ 
кая его из стека. 


’Машина базы данных 

Совершенно другой подход к реализации принципов ассоциа¬ 
тивности применен при проектировании машины базы данных 
DBC (database computer) в Университете шт. Огайо. Основные 
отличия машины DBC от процессоров RAP и CASSM заклю¬ 
чаются в следующем: 

1. По характеру элементов DBC является более разнород¬ 
ной системой по сравнению с системами RAP или CASSM. Хотя 
машина DBC содержит ячейки ассоциативного поиска, подоб¬ 
ные имеющимся в процессорах RAP и CASSM, они составляют 
незначительную часть элементов логической обработки дан¬ 
ных. 

2. В системе DBC каждая ячейка ассоциативного поиска 
оперирует не в своем единственном запоминающем устройстве, 
а в пределах пула (объединения) подобных устройств, которые 
имеют значительный объем памяти. В результате для систе¬ 
мы DBC характерна пониженная величина отношения числа 
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компонентов для ассоциативной обработки к числу адресуемых 
элементов памяти. 

3. В системе DBC, как и в традиционных СУБД, реализуе¬ 
мых программным способом, для доступа к данным использу¬ 
ется система индексов. Однако для обработки как данных, так 
и самих индексов применяются ассоциативные методы. 

4. В архитектуре DBC не заложено какой-либо определен¬ 
ной модели БД (реляционной, иерархической или сетевой). 
Поэтому модели обрабатываемых данных здесь примитивнее, 
чем в системах RAP или' CASSM, а возможности команд более 
ограниченны. 

5. Неотъемлемым компонентом DBC являются средства за¬ 
щиты от несанкционированного доступа к данным. 


СТРУКТУРА СИСТЕМЫ DBC 

Согласно рис. 21.3, структура системы DBC представляется в 
виде двух связанных замкнутых цепочек блоков обработки. 
Эти цепочки совместно используют процессор общего управле¬ 
ния и анализа команд данной СУБД (DBCCP — database com¬ 
mand and control processor). Обычная последовательность вы¬ 
полнения операций состоит в том, что сначала эти операции вы¬ 
полняются элементами цепочки обработки информации о струк¬ 
туре размещения данных, а затем — элементами цепочки выпол¬ 
нения операций над данными в основной памяти. В каждой из 
этих двух замкнутых цепочек могут быть выделены отдельные 
субблоки обработки (процессоры или наборы процессоров). 
В результате обработка групповых операций в этой системе вы¬ 
полняется в форме, типичной для конвейерных систем: в один 
и тот же момент времени эти операции могут обслуживаться 
разными субблоками обработки. 

Побуждающим мотивом разработки системы DBC явилось 
интуитивное предположение о том, что системы с регулярной 
структурой, такие, как RAP или CASSM, не будут рентабельны¬ 
ми в условиях больших БД ближайшего будущего. В поддержку 
такого утверждения можно привести два аргумента. Во-первых, 
несмотря на использование методов частично ассоциативного 
доступа в RAP и CASSM, отношение числа обрабатывающих 
элементов к числу элементов памяти в этих системах остается 
достаточно высоким. При работе с БД большого объема (по¬ 
рядка 10 10 байт и выше) при выполнении реляционным ассо¬ 
циативным процессором операции над отдельным отношением 
может оказаться задействованной лишь небольшая часть ячеек 
RAP (при общем количестве отношений, исчисляемом сотня¬ 
ми). В результате обрабатывающие средства системы оказы¬ 
ваются загруженными далеко не полностью. 
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Второй аргумент в пользу 
применения системы DBC вы¬ 
текает из стоимостной оценки 
памяти. Память систем RAP и 
CASSM основана на вращаю¬ 
щихся носителях типа магнит¬ 
ных дисков с фиксированны¬ 
ми головками или на их элек¬ 
тронных эквивалентах (па¬ 
мять на магнитных цилиндри¬ 
ческих доменах или элементах 
с зарядовой связью). Стои¬ 
мость памяти такого типа на 
порядок или более превыша¬ 
ет стоимость памяти, в кото¬ 
рой реализован традиционный 
способ хранения информации 
на дисках с перемещаемыми 
головками. В связи с этим 
структура процессора DBC должна была представлять собой 
машину базы данных с ассоциативным доступом на основе де¬ 
шевых накопителей на дисках с перемещаемыми головками, 
лишенную в то же время их очевидных недостатков. 

В системе DBC вначале в работу вступают блоки цепочки 
обработки информации о структуре размещения данных, а за¬ 
тем выполняются операции над данными основной памяти. Од¬ 
нако мы начнем рассмотрение с операций над данными основ¬ 
ной памяти, поскольку именно эти операции определяют само 
существование цепочки обработки информации о структуре раз¬ 
мещения данных. 

• ОПЕРАЦИИ НАД ДАННЫМИ 
В ОСНОВНОЙ ПАМЯТИ в СИСТЕМЕ DBC 

Основные элементы цепочки блоков, выполняющих операции 
над данными в основной памяти, показаны на рис. 21.4, а. В со¬ 
став этой подсистемы входят устройство управления и п «обра¬ 
ботчиков информации на дорожках» (TIP -элементы 1 )), где п — 
число дорожек в одном цилиндре дисковой памяти, т. е. число 
головок считывания/записи. Каждый из элементов TIP пред¬ 
ставляет собой ассоциативный процессор, напоминающий ячей¬ 
ку системы RAP или CASSM. Он не имеет постоянной связи с 
гкаким-либо единственным вращающимся носителем или до- 


*> TIP — аббревиатура, образованная от английских слов track informa¬ 
tion processors. — Прим, перев. 



Рис. 21.3. Две цепочки блоков 
обработки машины DBC. 
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рожкой. Данные в системе фактически могут храниться на мно¬ 
гих отдельных томах дисковой памяти со стандартными меха¬ 
низмами перемещения головок считывания/записи. Посредством 
устройства управления механизмом доступа к памяти и набора 
селекторов механизмов доступа каждый процессор обработки 




Рис. 21.4. Элементы основной памяти машины DBC. 

а — функциональная взаимосвязь элементов; б — модифицированное 
устройство управления на магнитных дисках. 


TIP может быть соединен с соответствующей дорожкой любого 
типа. Например, если в системе имеется 100 томов дисковой 
памяти, то процессор TIP1 может быть подсоединен к первой 
дорожке любого из этих 100 томов. 

Основной недостаток такого технического решения заклю¬ 
чается в том, что при использовании стандартных устройств 
управления накопителями на магнитных дисках с перемещаемы¬ 
ми головками считывание данных осуществляется поразрядно, 
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поочередно с отдельных дорожек. Такой режим передачи дан¬ 
ных обесценивает принцип закрепления за каждой дорожкой 
своего процессора (TIP), поскольку информация в каждый дан¬ 
ный момент времени могла бы поступать только к одному та¬ 
кому процессору. Для эффективной работы системы необходи¬ 
мо, чтобы имелась возможность выбора дисковода, установки 
головок считывания/записи на определенный цилиндр и одно¬ 
временной записи или чтения информации всех дорожек этого 
цилиндра (т. е. одновременного использования всех головок 
считывания/записи). Оказывается подобное изменение режима 
работы возможно без коренной переделки устройства управле¬ 
ния накопителем на магнитных дисках. Этот новый способ и 
применен в системе DBC. Схематически связь процессоров об¬ 
работки с головками считывания/записи изображена на 
рис. 21.4,6. 

Рассмотрим последовательность действий системы при вы¬ 
полнении операций над данными основной памяти. Сначала 
производится выбор накопителя. Затем головки считывания/за¬ 
писи устанавливаются на требуемый цилиндр. После этого 
данные со всех дорожек этого цилиндра параллельно считыва¬ 
ются в процессоры обработки TIP. По мере поступления дан¬ 
ных через селектор механизмов доступа в процессоры обработ¬ 
ки, последние выполняют анализ этих данных. Каждый из 
процессоров может передавать устройству управления основ¬ 
ной памятью информацию о результатах выполнения операции 
поиска. Вследствие высокой плотности записи данных на дис¬ 
ки, а также из-за технических затруднений, возникающих при 
попытке согласованного размещения нескольких головок на од¬ 
ной дорожке, в данной системе используются одни и те же го¬ 
ловки как для записи, так и для считывания информации (в 
системе RAP.1 для записи и считывания используются разные 
головки). Поэтому для модификации записей требуется не ме¬ 
нее двух оборотов диска. 

При указанной организации процессора основной памяти 
ассоциативность обработки данных достигается в пределах от¬ 
дельных цилиндров. Серьезным препятствием для эффективно¬ 
го использования системы является чрезмерно большое время, 
необходимое для поиска по всей БД, если отсутствует уточня¬ 
ющая информация о физическом расположении данных. С целью 
преодоления этой проблемы предусмотрено следующее: при по¬ 
ступлении в процессор DBCCP запроса на выполнение опера¬ 
ции устройство управления основной памятью получает также 
список номеров цилиндров (томов). Эта информация сужает 
область поиска, указывая только те части БД, где могут на¬ 
ходиться представляющие интерес данные. Помимо этого при¬ 
бегают к рациональной заблаговременной группировке данных 
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в БД (в частности, таким образом, чтобы данные, которые мо¬ 
гут служить предметом одновременных поисков, располагались 
на одном цилиндре или малом числе цилиндров). Благодаря 
этому при выполнении стандартных операций в DBC удается 
ограничиться просмотром всего лишь одного или нескольких, 
цилиндров, что существенно для преодоления основных труд¬ 
ностей, связанных с использованием накопителей на магнит¬ 
ных дисках с перемещаемыми головками. Кроме этого, устрой¬ 
ство управления основной памятью может поддерживать режим 
конвейерной обработки команд. А именно, в то время, когда 
процессоры обработки TIP выполняют анализ данных, полу¬ 
ченных с некоторого цилиндра, может быть выполнена пере¬ 
установка головок считывания/записи или выбран другой на¬ 
копитель на магнитных дисках в порядке подготовки к выпол¬ 
нению следующей операции. 

Эффективность операций над данными основной памяти в 
DBC существенно зависит от возможности предварительного' 
определения подмножества цилиндров, обработкой которых 
можно ограничиться. Именно для решения этой задачи в систе¬ 
му DBC введена цепочка блоков обработки информации о 
структуре размещения данных. 

ОБРАБОТКА ИНФОРМАЦИИ 
О СТРУКТУРЕ РАЗМЕЩЕНИЯ ДАННЫХ В DBC 

Цепочка блоков обработки информации о структуре размеще¬ 
ния данных в памяти выполняет роль механизма индексирова¬ 
ния. Но в отличие от стандартных схем индексирования, кото¬ 
рыми обеспечивается доступ к конкретной записи на конкретной 
дорожке заданного цилиндра, данная схема индексирования 
позволяет определять только соответствующие цилиндры. Окон¬ 
чательный же ассоциативный поиск данных выполняется по¬ 
средством операций над данными в основной памяти. 

Основными элементами цепочки блоков обработки инфор¬ 
мации о структуре размещения данных в основной памяти БД 
являются память структуры размещения данных и ее устрой¬ 
ство управления (рис. 21.5). Организация этой памяти подобна 
организации основной памяти хранения данных, отличия этих 
двух запоминающих устройств носят технологический харак¬ 
тер. Основное функциональное назначение памяти структуры 
размещения данных — определение для любого запроса к БД 
множества цилиндров, на которых расположено хотя бы по од¬ 
ной записи, удовлетворяющей параметрам запроса. Сам запрос 
представляется в виде дизъюнкции ключевых предикатов, под 
которыми понимают логические выражения, состоящие из имени 
атрибута, оператора отношения и значения (например, зарабо¬ 
ток >20000). 


14—429 
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Доступ к памяти структуры размещения данных организован 
также на основе ассоциативных способов обработки: в состав 
•обслуживающего ее процессора входит набор блоков ассоциа¬ 
тивных процессоров (АР). Подобно процессору основной памя¬ 
ти, и здесь связь между ассоциативными процессорами и соот¬ 
ветствующими запоминающими устройствами на вращающихся 
носителях не является фиксированной, раз и навсегда заданной. 
С помощью переключателей каждый ассоциативный процессор 


Запросы 



Рис. 21.5. Процессор 
памяти структуры 
размещения данных 
машины DBC. 


может быть соединен с одним вращающимся носителем из не¬ 
которого их набора. В памяти структуры размещения данных 
хранятся по существу индексы доступа к данным основной па¬ 
мяти. Поскольку для хранения индексов требуется намного 
меньше места, чем для данных, память структуры размещения 
данных оказывается возможным реализовать как память на 
магнитных цилиндрических доменах или на элементах с заря¬ 
довой связью. 

Из-за упомянутых множественных связей между отдельными 
вращающимися носителями и блоками ассоциативной обработ¬ 
ки желательно использовать группировку (согласованное разме¬ 
щение) записей в памяти структуры. Так, если в памяти струк¬ 
туры размещения данных выполняется простая операция поис¬ 
ка всех цилиндров, содержащих записи, удовлетворяющие пре¬ 
дикату ЗАРАБОТОК >20000, хотелось бы, чтобы данные об 
индексах цилиндров для атрибута ЗАРАБОТОК не располага¬ 
лись в модулях памяти, связанных лишь с одним ассоциатив¬ 
ным процессором. В последнем случае отсутствовал бы парал- 
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лелизм обработки информации в памяти структуры размещение 
данных. Для обеспечения параллелизма информацию в памяти 
структуры размещения данных следует располагать таким об¬ 
разом, чтобы индексы цилиндров для определенных атрибутов 
по возможности распределялись по модулям памяти, связанны» 
с различными процессорами. 

ПРЕДСТАВЛЕНИЕ ДАННЫХ В МАШИНЕ DBC 

Записи, хранимые в основной памяти БД, состоят из трех час¬ 
тей: идентифицирующей части, набора пар «атрибуты-значение» 
и информационной части. Формат записи представлен на 
рис. 21.6. Записи, которые вероятнее всего будут обрабатывать- 

I С I s I К |а,| L, I У, |a 2 |l 2 | У; | .. . \* K \u\ Ѵк 


Рис. 21.6. Формат записи в машине DBC. 

С — номер кластера; S — идентификатор блока санкционированного доступа; 
К — число ключевых слов в записи; А, — номер атрибута; L, — длина поля 
V, — значение ключевого слова; А|<...<А К . 


ся совместно, размещают на возможно меньшем количестве 
цилиндров. Это обеспечивается специальным механизмом груп¬ 
пировки. При вводе записи для хранения в машину DBC из ве¬ 
дущей машины должен также поступать идентификатор конк¬ 
ретной группы — кластера — данных, к которой должна быть 
«приписана» эта запись. Кластер можно представить себе в 
виде некоторого файла, хотя и не обязательно. Каждая запись 
включает идентификатор кластера, которому она принадлежит. 

В идентифицирующей части записи содержится также ука¬ 
затель блока санкционированного доступа, которому принад¬ 
лежит эта запись. Пусть, например в системе учета кадров не¬ 
обходимо принять меры по защите некоторых записей класте¬ 
ра от доступа каких-либо пользователей или программ. Клас¬ 
тер может содержать данные как о штатных сотрудниках, так и 
о совместителях, т. е. сотрудниках с неполной рабочей неделей 
(работающих на полставки). Предположим, задача заключает¬ 
ся в том, чтобы разрешить доступ отдельным пользователям 
БД лишь к информации о совместителях. Для этого достаточ¬ 
но ввести два блока санкционированного доступа и организо¬ 
вать работу таким образом, чтобы группа пользователей имела 
доступ лишь к одному из этих блоков. 

Вторая часть записи состоит из пар «атрибуты-значение». 
Каждую такую пару называют ключевым, словом, являющимся 

14* 
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.по сути самоопределяемыми данными. Идентификатор ключе¬ 
вого слова является номером атрибута. Перечисление атрибу¬ 
тов в записи упорядочено по убыванию номеров, хотя в самой 
последовательности номеров допустимы пробелы. Такое упо¬ 
рядочение ключевых слов в записи позволяет упростить про¬ 
цедуру поиска, ибо информация о запросе, передаваемая в про¬ 
цессор основной памяти (триплеты «атрибут-отношение-значе- 
ние»), также должна быть упорядочена по убыванию номеров 
атрибутов. 

Возможности ассоциативной обработки в БД распространя¬ 
ются не на всю структуру записи, а лишь на данные, зафикси¬ 
рованные в парах «атрибут-значение». Данные, не подлежащие 
ассоциативной обработке, размещаются в информационной 
части записи. Они воспринимаются системой как последова¬ 
тельности символов, которые могут быть записаны в БД или 
извлечены из нее. 


НАБОР КОМАНД, 

используемый в машине dbc 

По сравнению с процессорами RAP и CASSM в машине DBC 
используется простой набор команд. Команда поиска и извлече¬ 
ния данных имеет следующий формат: 

RETRIEVE (идентификатор файла, список полей, условие 
отбора записей) 

В списке полей перечисляются имена всех атрибутов, зна¬ 
чения которых должны быть получены в результате поиска. Ус¬ 
ловие отбора значений представляется дизъюнкцией ключевых 
предикатов, состоящих из имени атрибута, оператора отноше¬ 
ния и значения. 

К числу основных команд, используемых в системе DBC, от¬ 
носятся также следующие команды: DELETE — исключение 
всех записей, которые удовлетворяют условию отбора; 
INSERT — добавление записи в БД (задается и обрабатывает¬ 
ся информация о кластерах); REPLACE — задание списка клю¬ 
чевых слов (пар «атрибуты-значение») с целью замены ими те¬ 
кущих значений атрибутов во всех записях, удовлетворяющих 
условию отбора. 


БЛОКИ ОБРАБОТКИ МАШИНЫ DBC 

Основными блоками машины DBC, в которых выполняется 
ассоциативная обработка, являются основная память и память 
структуры размещения данных. Помимо этого, в системе DBC 
имеется несколько других блоков, участвующих в обслужива- 
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нии запросов к БД. Полная структура DBC, всключающая эти 
блоки, показана на рис. 21.7. 

Наиболее удобный способ ознакомления с взаимодействием 
между отдельными блоками заключается в рассмотрении после¬ 
довательной обработки запроса блоками двух упоминавшихся 



Рис. 21.7. Обработка запроса в машине DBC. 


ранее замкнутых цепочек, образующих DBC. При этом следует 
учитывать, что обработка запросов в обоих цепочках имеет в 
значительной степени конвейерный характер, а именно: в то 
время как параметры некоторого запроса обрабатываются ка¬ 
ким-либо одним блоком (элементом цепочки), в остальных бло¬ 
ках этой цепочки может выполняться обработка других запро¬ 
сов. 

При поступлении запроса в DBCCP ( процессор общего уп¬ 
равления и анализа команд системы DBC) условие отбора за¬ 
писей передается в преобразователь ключевых слов (keyword 
transformation unit — KXU). Выше отмечалось, что память 
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структуры размещения данных служит для определения место¬ 
положения небольшого подмножества записей основной памяти, 
в котором должен быть проведен поиск. Блок KXU выполняет 
аналогичные функции, но уже по отношению к самой памяти 
структуры размещения данных. В указанном блоке вырабаты¬ 
вается информация для процессора памяти структуры разме¬ 
щения данных о группах элементов в этой памяти, которые 
подлежат ассоциативной обработке для нахождения данных о 
цилиндрах. В блоке KXU имеется своя память со всеми атрибу¬ 
тами (именами полей или идентификаторами), определяющими 
БД системы DBC. Условия отбора записей формулируются в 
виде одного или нескольких атрибутов, задаваемых идентифи¬ 
каторами переменной длины. Преобразователь KXU переводит 
каждое из этих имен в специальный идентификатор атрибута 
с постоянной длиной. Он также выделяет числовые значения 
из условий отбора записей (например, значение 20 000 из преди¬ 
ката ЗАРАБОТОК >20 000, построенного с использованием со¬ 
ответствующего ключевого слова) и передает пары управляю¬ 
щих данных — идентификатор атрибута в виде числа и выде¬ 
ленное значение — процессору памяти структуры размещения 
данных. Каждая из этих пар называется идентификатором 
группы, поскольку она определяет, какие именно модули со¬ 
ставной памяти, связанные с каждым из ассоциативных про¬ 
цессоров памяти структуры размещения данных, содержат со¬ 
ответствующую информацию об индексах. Так функционирует 
в памяти структуры размещения данных упоминавшийся выше 
механизм группировки. 

Исходными данными для работы процессора памяти струк¬ 
туры размещения данных (рис. 21.5) является список групп 
элементов, соответствующий условиям отбора записей. Путем 
ассоциативного просмотра информации об индексах процессор 
преобразует этот список в список индексирующих элементов. 
Последние состоят из относительного номера цилиндра и номе¬ 
ра блока защиты от несанкционированного доступа. Например, 
условие отбора записей 

ЗАРАБОТОК >20 000 или ВОЗРАСТ = 65 

может привести к формированию списка из пяти индексиру¬ 
ющих элементов. 

Список индексирующих элементов передается в информаци¬ 
онный процессор памяти структуры размещения данных (struc- 
fure memory information processor — SMIP). Этот процессор 
выполняет поэлементную проверку списка на пересечение и со¬ 
кращает размер списка путем исключения из него элементов 
с дублирующими номерами цилиндров. 
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Процессор SMIP пересылает получившийся список в блок 
преобразования индекса (index translation unit —IXU). В этом 
<5локе выполняется простое преобразование индексирующих 
элементов. Дело в том, что блоки памяти структуры размеще¬ 
ния данных оперируют не абсолютными, а относительными но¬ 
мерами цилиндров. Так, если файл расположен на пяти ци¬ 
линдрах, при поиске записей этого файла будут использоваться 
относительные номера цилиндров 0—4. Применение относитель¬ 
ных номеров обеспечивает более компактное хранение индексов 
в памяти структуры размещения данных. В блоке IXU имеется 
память соответствий между относительными номерами цилинд¬ 
ров в файлах и абсолютными номерами цилиндров. Блок IXU 
просто выполняет преобразование номеров цилиндров в списке 
индексирующих элементов из относительных в абсолютные. 

Сформированный список индексирующих элементов переда¬ 
ется обратно в процессор DBCCP. Этот процессор выполняет 
так называемую проверку типа А на наличие санкционирован¬ 
ного доступа. Она основывается на анализе данных хранимых 
в DBCCP списков указателей блоков санкционированного до¬ 
ступа, с которыми могут работать отдельные пользователи. По¬ 
дучив из блока IXU список индексирующих элементов, процес¬ 
сор DBCCP выполняет сравнение номеров цилиндров в этом 
списке с номерами в списке цилиндров, доступных пользовате¬ 
лю. Если при сопоставлении будут обнаружены индексирующие 
элементы, доступ к которым пользователю не разрешен, они 
исключаются из списка. (Проверку нельзя назвать полной, по¬ 
скольку возможно несоответствие между размерами блоков 
санкционированного доступа и объемом памяти выделенных 
цилиндров. Дополнительная проверка на наличие санкциониро¬ 
ванного доступа выполняется на уровне процессора основной 
памяти во время считывания и обработки записей.) 

Обработанный и, возможно, сокращенный список индекси¬ 
рующих элементов пересылается процессору основной памяти. 
Последний, как отмечалось, обеспечивает ассоциативный доступ 
к данным на основе дисковой памяти с подвижными головками 
(рис. 21.4). Из блоков санкционированного доступа, к которым 
может обращаться данный пользователь, процессор основной 
памяти извлекает записи, удовлетворяющие условию отбора. 
Выделенные записи пересылаются в фильтр доступа (security 
filter — SFP). 

Фильтр доступа, представляющий собой еще одно средство 
контроля, выполняет проверку на наличие санкционированного 
доступа на уровне полей записи, именуемую проверкой типа В. 
В результате можно ограничить доступ пользователя не только 
к отдельным группам записей (путем указания блоков санкцио¬ 
нируемого доступа), но и к отдельным типам полей в записях. 
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а также к данным, значения которых выходят за установленные 
границы. Если, например, в блок SFP передаются указания о 
том, что пользователь X не должен иметь доступа к атрибу¬ 
ту ЗАРАБОТОК, фильтр после получения записей из основной 
памяти, удаляет из них соответствующую информацию (пары 
«атрибут-значение»). 

После всех указанных преобразований отфильтрованные 
данные — результат обработки запроса — передаются в основной 
процессор DBCCP. 


ПРОИЗВОДИТЕЛЬНОСТЬ МАШИНЫ DBC 

Как можно заметить, принципы построения системы DBC суще¬ 
ственно отличаются от принципов, положенных в основу систем 
RAP и CASSM. Достижение высокой производительности систе¬ 
мы DBC связывают со способностью этой машины базы данных 
выполнять в различных элементах двух ее цепочек одновремен¬ 
но обработку нескольких запросов. Сокращение расходов при 
использовании системы DBC предполагается достичь за счет 
относительно меньшего объема обрабатывающих элементов на 
единицу объема основной памяти. 

Приближенная итоговая оценка производительности маши¬ 
ны DBC может быть подсчитана следующим образом [5]. Про¬ 
цессор основной памяти при реализации ее на дисках с пере¬ 
мещаемыми головками выполняет поиск в пределах цилиндра 
за один оборот носителя. Допуская, что цилиндр содержит 
40 дорожек, и учитывая, что в стандартных системах выпол¬ 
няется последовательное поразрядное считывание в каждый 
момент времени лишь с одной дорожки, получаем сорокакрат¬ 
ное увеличение эффективности. Кроме того, поскольку, в то 
время как обрабатывается некоторый запрос в основной памя¬ 
ти, в процессоре памяти структуры может обрабатываться дру¬ 
гой запрос, имеем еще двукратное увеличение эффективности. 
Наконец, вследствие конвейерного характера обработки (в обе¬ 
их цепочках блоков обработки системы DBC могут одновремен¬ 
но обслуживаться четыре-пять запросов) можно рассчитывать 
на дополнительное повышение эффективности примерно в два 
раза. Таким образом, производительность системы DBC может 
превысить производительность традиционных СУБД в 160 и бо¬ 
лее раз. 
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ГЛАВА 22 

АРХИТЕКТУРА МАШИН, 

УПРАВЛЯЕМЫХ ПОТОКОМ ДАННЫХ 1 » 

Рассмотренные выше варианты построения архитектуры вычис¬ 
лительных машин значительно отличаются от традиционной сов¬ 
ременной архитектуры и в то же время сохраняют ее некото¬ 
рые общие основные характеристики. К таким характеристикам 
относятся, во-первых, последовательное увеличение содержимо¬ 
го счетчика команд при переходе от одной команды к другой; 
во-вторых, пассивная природа памяти (исключением является 
память ассоциативного типа); в-третьих, возможность парал¬ 
лельного выполнения операций, что подразумевает коммутацию 
процессора между различными процессами и принудительное 
разделение программы и данных таким образом, чтобы они 
обрабатывались одновременно разными процессорами. 

Машинам потоков данных все перечисленные характеристи¬ 
ки не свойственны: отсутствует понятие о последовательности 
выполняемых команд и передаче управления, память не рас¬ 
сматривается как пассивное хранилище переменных програм¬ 
мы, и, наконец, вводятся средства для обнаружения и эффектив¬ 
ного использования ситуаций, допускающих параллельную об¬ 
работку в программе без явных на то указаний программиста. 

Появление машин потоков данных обусловлено тремя основ¬ 
ными причинами: потребностью в существенном увеличении вы¬ 
числительной мощности, серьезными недостатками принципов 
построения современных языков программирования и наличием 
«узких мест» в физической структуре традиционных машин. 

Первая причина — отсутствие достаточной вычислительной 
мощности — является значительным препятствием для примене- 


•> Следует обратить внимание на то, что машины, управляемые потоком 
данных (машины потоков данных), разрабатываются совершенно для других 
целей, чем рассмотренные в предыдущих главах машины базы данных. Впро¬ 
чем, у машин того и другого типа имеется ряд схожих свойств: высокая сте¬ 
пень параллелизма выполнения операций и регулярности (однородности) 
структуры машины, наличие в памяти встроенных схем обработки информа¬ 
ции. 
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ния машин при решении важных проблем. Хотя в наши дни 
ЭВМ с успехом применяют для экономических расчетов (под¬ 
готовка платежных ведомостей, начисление страховых премий, 
бухгалтерский учет, ведение расчетов по кредитным карточ¬ 
кам), вычислительные машины плохо приспособлены для реше¬ 
ния задач в области создания искусственного интеллекта, рас¬ 
познавания образов, обработки речевой информации, прогнози¬ 
рования погоды, проектирования аэродинамических конструк¬ 
ций, перевода с одного иностранного языка на другой, сейсми¬ 
ческого анализа и многих других. В качестве примеров, под¬ 
тверждающих значительность проблемы, приведем следующие 
факты. Новому поколению машин автоматического перевода с 
одного иностранного языка на другой понадобятся процессоры, 
способные выполнять 2—3 млрд, операций в секунду. Для со¬ 
ставления местного краткосрочного прогноза погоды (на сутки) 
по результатам наблюдений за состоянием атмосферы потребу¬ 
ется скорость порядка 100 млрд, операций в секунду. Модели¬ 
рование действия подъемной силы на крыло самолета и турбу¬ 
лентности воздушного потока возможно при наличии вычисли¬ 
тельных систем, обеспечивающих выполнение 1 млрд, операций 
в секунду над числами с плавающей точкой. Эффективность 
будущих военных разработок зависит от бортовых вычислитель¬ 
ных машин самолетов, кораблей и космических аппаратов, про¬ 
изводительность которых должна быть по крайней мере на по¬ 
рядок выше, чем у современных аналогичных машин. 

Традиционным решением задачи увеличения мощности сис¬ 
темы (после того как производительность единственного про¬ 
цессора доведена до максимального значения) является исполь¬ 
зование нескольких процессоров. Однако такой подход не яв¬ 
ляется удовлетворительным в силу действия следующих обстоя¬ 
тельств. Во-первых, возникают проблемы программирования, 
обусловленные необходимостью для программиста «подгонять» 
структуру данных и программ под жесткую структуру много¬ 
процессорной или распределенной вычислительной системы. 
Например, при работе с системой, содержащей 16 процессоров, 
программисту приходится разбивать свою программу на 16 или 
•более параллельных процессов. Задача далеко не тривиальная, 
и современные языки программирования, средства обслужива¬ 
ния и отладки едва ли могут здесь оказать какую-либо сущест¬ 
венную помощь. 

Во-вторых, в традиционных мультипроцессорных системах 
в режиме разделения памяти между процессорами возможны 
наложения обращений к памяти —так называемая интерфе¬ 
ренция обращений к памяти. Поскольку каждый отдельный 
процессор стремится захватить определенную часть памяти, 
подключение новых процессоров к памяти, уже разделяемой 
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другими процессорами, может дать только ограниченную выго¬ 
ду. Интерференция обращений к памяти может быть уменьше¬ 
на, если каждый процессор снабдить локальным кэш-буфером 
(кэш-памятью). Однако при этом возникает другая проблема: 
некоторая ячейка памяти может оказаться привязанной к не¬ 
скольким кэш-буферам, т. е. операция записи одного процессо¬ 
ра может повлечь за собой искажение информации в кэш-бу¬ 
ферах других процессоров. Таким образом, хотя мультипроцес¬ 
сорные системы имеют определенные достоинства, повышая сте¬ 
пень готовности системы для решения различных задач, они 
все же уступают однопроцессорным аналогам по такому кри¬ 
терию, как отношение стоимости к производительности. 

Второй причиной появления машин потоков данных являют¬ 
ся недостатки, присущие самой природе современных языков 
программирования, и осознание того факта, что эти языки от¬ 
ражают в своей структуре основополагающие принципы архи¬ 
тектуры машин фон Неймана [1, 2]. Помимо перечисленных 
в гл. 2 принципов построения архитектуры к традициям, зало¬ 
женным фон Нейманом, можно отнести также и внутреннюю 
организацию современных машин. Упомянутая организация 
предполагает использование пассивной памяти, процессора, 
выполняющего операции по изменению содержимого памяти, 
и устройства управления, воздействующего на процессор с по¬ 
мощью потока следующих одна за другой команд. Понятие «пе¬ 
ременная» в языке программирования адекватно понятию «об¬ 
ласть пассивной памяти» в машине, понятие «передача управ¬ 
ления» в языке (реализуемая, например, операторами GO ТО, 
IF, DO, CALL) отображает устройство управления и счетчик 
команд в машине фон Неймана. Подобным же образом понятие 
«присваивание» является отображением определенной операции 
процессора (изменения содержимого области памяти машины). 
Использование потока данных для управления машиной позво¬ 
лило сделать выводы, с которыми согласились и специалисты 
в области теории языков: во-первых, три указанные в начале 
раздела основные характеристики традиционных машин явля¬ 
ются искусственными, не соответствуют естественному порядку 
реализации алгоритмов решения задач и усложняют процесс 
программирования; во-вторых, современные языки программи¬ 
рования являются продуктом развития представлений не «сна¬ 
ружи внутрь» (т. е. не исходя из точки зрения программиста), 
а «изнутри наружу» (под сильным влиянием организации пер¬ 
вых машин с запоминаемой программой). 

Третьей причиной появления машин потоков данных являет¬ 
ся осознание того факта, что тракт, соединяющий процессор с 
памятью, является тем самым «узким местом», которое в ос¬ 
новном и ограничивает эффективность системы (этот вывод. 
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был сделан ранее в гл. 2). В современных вычислительных 
системах назначение программы заключается в изменении со¬ 
держимого памяти, предоставляемой для данных этой програм¬ 
мы. Достигается это путем «проталкивания» одиночных команд 
и данных через узкую магистраль, связывающую память и про¬ 
цессор. 


ПРИНЦИП действия машин 
ПОТОКОВ ДАННЫХ 

Машины потоков данных производят наиболее сильное впечат¬ 
ление тем, что принципы их проектирования не базируются на 
основных свойствах и характеристиках традиционных машин и 
языков программирования. В архитектуре машин потоков дан¬ 
ных отсутствует понятие «пассивная память данных», а в языке 
потоков данных нет понятия «переменная»: данные перемеща¬ 
ются из команды в команду по мере выполнения программы. 

Кроме того, в данном случае не используются понятия «пе¬ 
редача управления», «счетчик команд» и «ветвление вычисли¬ 
тельного процесса». Вместо этого команды (операторы) управ¬ 
ляются данными. Считается, что команда готова к выполнению” 
(т. е. ее выполнение разрешено), если данные присутствуют 
в каждом из ее входных портов и отсутствуют в выходном 
порте. Выполнение команды приводит к исчезновению данных 
в ее входных портах и появлению результата в выходном пор¬ 
те. Программа представляет собой направленный граф, обра¬ 
зованный соединенными между собой командами: выходной- 
порт одной команды соединен с входным портом другой коман¬ 
ды. Таким образом, порядок выполнения команды определяется 
не счетчиком команд, а движением потока данных в командах. 

Указанные принципы выполнения команд иллюстрируег 
рис. 22.1. Здесь окружности обозначают команды, стрелки — 
линии связи между командами, а зачерненные круги — данные. 

Первые три команды показаны в состоянии запрета на вы¬ 
полнение. У первой команды нет входных данных, у второй 
данные присутствуют не на всех входных линиях, а в третьей 
команде имеются данные — предыдущий результат — на выход¬ 
ной линии. Четвертая команда имеет все, что необходимо для 
получения разрешения на выполнение, т. е. готова к выполне¬ 
нию. Выполнение команды приводит к исчезновению данных co - 
входных линий и появлению результата на выходной линии. 

На рис. 22.2 с помощью рассмотренных символических обо¬ 
значений описывается решение квадратного уравнения. Возни¬ 
кает необходимость ввести два дополнительных понятия. Пер¬ 
вым является размножитель, который представляет собой one- 



.рацию с одним входом и несколькими выходами. Он готов к ра¬ 
боте, когда на входной линии данные присутствуют, а выходные 
линии пусты. Его функции — распределять входные данные по 
всем выходным линиям. Размножитель обозначается небольшим 
зачерненным кругом. (Не путать с обозначением данных 
(рис. 22.1)! — Прим, перев.) Вторым новым понятием является 
>бесконечный источник констант для команды. Например, после 


> Команды не готовы н Выполнению 

у 


Ломанда готова Результат 

к выполнению выполнения 


Рис. 22.1. Возможные состояния 
команд в машине потоков данных. 



Рис. 22.2. Алгоритм решения 
квадратного уравнения в машине 
потоков данных. 





выполнения операции умножения 2 на А, константа 2 немедлен¬ 
но снова воссоздается на одной из входных линий. 

У читателя может возникнуть желание проследить путь пе¬ 
ремещения данных по графу. (Отметим, что некоторые вопросы, 
такие, как порядок выполнения операций вычитания и деления, 
здесь не рассматриваются.) Следует обратить внимание на то, 
что целый ряд операций может оказаться готовым к выполне¬ 
нию в один и тот же момент времени и, следовательно, возмож¬ 
но их параллельное выполнение. Схема рис. 22.2 иллюстрирует 
тот принцип, что команды не запрашивают операнды традици¬ 
онным способом, а указывают посредством соединительных ли¬ 
ний, к каким командам направляются результаты их работы — 
<их выходные линии. Таким образом, принципы построения гра- 
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фа потока данных во многом подобны прин¬ 
ципам построения сетей Петри [3]. 

Граф потоков данных можно рассматри¬ 
вать и на более высоком уровне абстракции, 
или обобщения. Примером является схема, 
приведенная на рис. 22.3. Следовательно, и 
подлежащая решению задача может быть 
представлена с различной степенью обобще¬ 
ния, например такой, когда граф потоков дан¬ 
ных полностью заменен единственным опера¬ 
тором на графе более высокого уровня . 

ЯЗЫК ПОТОКОВ ДАННЫХ 

Прежде чем изучать архитектурные особенно¬ 
сти машин потоков данных, рассмотрим бо¬ 
лее подробно сам принцип обслуживания 
этими машинами потоков данных на уровне 
языка программирования. С этой целью оз¬ 
накомимся со специальным языком, предложенным Деннисом 
и его коллегами из Массачусетского технологического институ¬ 
та [4—6], где проводятся наиболее серьезные исследования в 
области машин потоков данных. 

Хотя язык Денниса является языком двумерного графичес¬ 
кого описания объектов программирования, существуют и дру¬ 
гие предложения по построению подобных языков [7—11], 
предполагающие представление программ потоков данных в бо¬ 
лее привычном виде —в форме последовательности операторов, 
подчиняющихся определенному синтаксису такого языка. 

Как упоминалось выше, в языке потоков данных не исполь¬ 
зуются понятия «переменная» и «передача управления». Прог¬ 
рамма записывается в виде набора операторов, активируемых 
данными и соединенных однонаправленными линиями передачи 
В основу языка Денниса положены следующие три основных 
понятия: исполнительный элемент, информация и линия связи. 

Исполнительный элемент символизирует операцию, готовую» 
к выполнению при поступлении информации на входные линии 
этого элемента и при отсутствии информации на его выходных 
линиях. Существуют два типа исполнительных элементов — бло¬ 
ки (actor) и размножители (link). Блок — это исполнительный 
элемент с одной выходной линией и одной или несколькими 
входными, размножитель — с одной входной линией и несколь¬ 
кими выходными. 

Информация в языке Денниса представляется в виде токе¬ 
нов, которые передаются по линиям связи, обрабатываются п> 
выдаются исполнительными элементами. 
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Рис. 22.3. 
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Различают два основных вида информации: значения данных 
(например, числовые величины) и значения управляющих сиг¬ 
налов (логические величины TRUE — ИСТИННО или FALSE — 
ЛОЖНО). В описываемом языке отсутствуют средства для 
распознавания типов значений данных (целые, с фиксирован¬ 
ной точкой, с плавающей точкой, комплексные и т.д.). Некото¬ 
рые расширения языка, связанные с обработкой структур дан¬ 
ных, рассматриваются в одном из следующих разделов. 


"А 
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і блок выпол¬ 
нения 
операции 
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Вентиль F 
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Рис. 22.4. Исполнительные элементы графического 
языка. 


Используемое в языке Денниса понятие линия связи (arc) 
символизирует однонаправленный тракт, по которому информа¬ 
ция передается от одного исполнительного элемента к друго¬ 
му. Сигналы на линии связи могут отсутствовать либо на ней 
•может находиться только 1 токен информации. Следовательно, 
линию связи можно рассматривать как определенный эквива¬ 
лент традиционных понятий «переменная» и «область памяти». 
В соответствии с классификацией информации на значения 
данных и значения управляющих сигналов линии также разде¬ 
ляются на линии данных (обозначены на рисунках сплошными 
стрелками) и управляющие линии (обозначены штриховыми 
стрелками). 

На рис. 22.4 изображены исполнительные элементы языка: 
сплошные стрелки показывают места подсоединения линий 
данных, штриховые — управляющих линий. Операция размно- 
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жения готова к выполнению при появлении токена на единст¬ 
венной входной линии размножителя и при условии, что все 
его выходные линии пусты. Размножитель распределяет полу¬ 
ченный токен по выходным линиям. Блок выполнения операции 
обычно имеет одну или две входные линии. Блок готов к рабо¬ 
те при наличии токенов данных на всех его входных линиях и 
при условии, что выходная линия пуста. Он принимает вход¬ 
ные токены, выполняет некоторые преобразования над получен¬ 
ными величинами и помещает результирующий токен данных 
на свою выходную линию. Типичными операциями таких бло¬ 
ков являются сложение, вычитание, умножение, инвертирова¬ 
ние, извлечение квадратного корня и т. д. 

Блок принятия решения функционирует аналогичным обра¬ 
зом, однако результатом его работы является управляющий сиг¬ 
нал (логическая величина). В этом блоке вычисляется отноше¬ 
ние, составленное из выходных данных, и формируется резуль¬ 
тат в виде логической величины TRUE (ИСТИННО) или 
FALSE (ЛОЖНО). Типичными операциями отношения являют¬ 
ся операции сравнения двух величин по одному из критериев 
типа «равны», «не равны», «первая величина больше второй» 
и т. д. 

Остальные три блока имеют на входе и данные, и управля¬ 
ющие сигналы. Блок типа вентиль Т (Т — от английского сло¬ 
ва TRUE) готов к работе при наличии на его входах как то¬ 
кена данных, так и токена управляющей информации (при 
этом, как обычно, выходная линия должна быть пуста). Как и 
все остальные исполнительные элементы, этот блок «поглощает» 
входную информацию во время выполнения. Если значение 
управляющего сигнала TRUE, то имеющийся на входе блока 
токен данных передается на выходную линию. Если значение 
управляющего сигнала FALSE, то сигнал на выходе блока не 
формируется. Таким образом, вентиль Т либо пропускает вход¬ 
ные данные на свой выход, либо просто «поглощает» их. Блок 
типа вентиль F (F — от английского слова FALSE) работает 
аналогичным образом, только для передачи токена данных на 
выходную линию требуется управляющий сигнал, имеющий зна¬ 
чение FALSE. 

Среди различных блоков рассматриваемого языка потоков 
данных блок типа «смеситель» является исключением: выпол¬ 
нение предписываемых им действий не вызывает уничтожения 
всех токенов на входных линиях, и для перехода его в состоя¬ 
ние готовности к работе не требуется наличия всех входных 
токенов. Этот блок готов к работе при соблюдении одного из 
следующих условий: 1) одновременное присутствие управляю¬ 
щего токена TRUE и токена данных на линии с меткой Т; 
2) одновременное присутствие управляющего токена FALSE и 
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токена данных на линии с меткой F. В обоих случаях выход¬ 
ная линия должна быть пуста. Если присутствует управляющий 
токен TRUE, токен данных с входной линии Т пересылается 
на выходную линию. В результате эти два токена на входных 
линиях уничтожаются, но при наличии токена данных на ли¬ 
нии F он сохраняется. Если присутствует управляющий токен 
FALSE, то токен данных на входной линии F пересылается на 
выходную линию. В результате этого два токена на входных 
линиях уничтожаются, но токен данных на линии Т, если он 
присутствовал, сохраняется. 

Свойства рассматриваемого языка нагляднее всего можно 
продемонстрировать на примере выполнения программы. Про¬ 
стая программа, выбранная для изучения, сначала записывает¬ 
ся на языке типа ПЛ/1: 

Z: PROCEDURE (X,Y); 

DO I = 1 ТО X; 

IF Y>1 THEN Y = Y*Y; 

ELSE Y = Y+Y+2; 

END; 

END; 

Представление этой программы на языке потоков данных 
показано на рис. 22.5. Такая форма представления выглядит 
более громоздко, чем приведенная выше процедурная запись. 
Однако следует иметь в виду, что язык потоков данных еще 
не сформулирован окончательно и вполне возможно, что со вре- 



Рис. 22.5. Графическое представление программы потоков данных. 
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менем будет разработан синтаксис этого языка, более тради¬ 
ционный по форме. 

Сопоставляя рис. 22.5 с программой на языке, подобном 
языку ПЛ/1, можно установить их взаимное соответствие. Ле¬ 
вая часть рис. 22.5 представляет собой в основном тело цик¬ 
ла DO; правая часть отображает выполнение оператора DO. 
Отметим, что некоторые блоки имеют на входных линиях кон¬ 
станты. Смысл этого заключается в том, что как только блок 



выполняет предписанную ему работу, константа вновь автома¬ 
тически воспроизводится на линии. 

Рассмотрим выполнение программы на языке потоков дан¬ 
ных при значениях входных переменных X и У, равных 2 и О 
соответственно. Прежде всего программа должна быть приве¬ 
дена в некоторое начальное состояние путем задания на графе 
определенных управляющих токенов. На рис. 22.6 показано та¬ 
кое начальное состояние программы. Управляющие токены на 
управляющих входных линиях трех смесителей в верхней части 
схемы имеют начальные значения. Управляющие токены и то¬ 
кены данных обозначаются на рисунках явным указанием их 
значений. 

В соответствии с начальным состоянием программы, отобра¬ 
женным на рис. 22.6, три блока готовы к работе. Смеситель, 
расположенный вверху слева, готов к выполнению своих функ¬ 
ций, поскольку к нему приложен управляющий токен FALSE, 
а на его входной линии F имеется токен данных. Два других 
смесителя находятся в состоянии готовности по тем же причи- 
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нам. Таким образом, при наличии соответствующих аппаратных 
средств, реализующих архитектуру машины потока данных, эти 
три смесителя могут функционировать параллельно. Для об¬ 
суждения здесь хода выполнения программы следует рассмат¬ 
ривать работу каждого блока шаг за шагом, принимая во вни¬ 
мание, что, во-первых, в каждый момент времени несколько 
блоков могут быть одновременно готовы к работе, т. е. обеспе¬ 
чена возможность их параллельной работы, и, во-вторых, ход 
выполнения программы не зависит от того, в каком порядке 



функционируют готовые к работе блоки (если вообще сущест¬ 
вует какой-либо определенный порядок их функционирования). 

Далее следует пропустить эти значения входных величин че¬ 
рез программу, пока не будет получено значение результата на 
выходной линии. Поскольку пошаговый анализ этой процедуры 
займет много времени и весьма утомителен, ограничимся рас¬ 
смотрением нескольких «мгновенных снимков» состояния прог¬ 
раммы в процессе выполнения указанных действий. 

Результатом работы смесителя, находящегося вверху слева, 
является передача величины 0 через размножитель на шесть 
входных линий других блоков. В результате работы смесителя, 
расположенного справа, величина 2 через размножитель посту¬ 
пает обратно на вход Т того же смесителя и, кроме того, на 
блок принятия решения. Работа среднего смесителя завершает¬ 
ся подачей величины 1 на исполнительный блок и блок приня¬ 
тия решения. 
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Полученное в результате описанных действий состояние про¬ 
граммы—первый «мгновенный снимок» — показано на рис. 22.7. 
Теперь пять блоков готовы к работе и могут функционировать 
параллельно. Блок принятия решения по критерию «первый 
операнд отношения больше второго» формирует управляющий 
токен FALSE, который посылается в три блока: вентили Т и F 
и нижний смеситель. В результате срабатывания блока приня¬ 
тия решения по критерию «первый операнд отношения меньше 
или равен второму» формируется управляющий токен TRUE, 



направляемый четырем адресатам. Блок операции сложения, 
расположенный в середине схемы, также готов к работе, он по¬ 
шлет величину 2 обратно на вход среднего смесителя. Эта опе¬ 
рация сложения эквивалентна сложению внутри цикла DO в 
программе на языке, подобном языку ПЛ/1. 

На рис. 22.8 приведен второй «мгновенный снимок», отобра¬ 
жающий следующее состояние программы. В этот момент гото¬ 
вы к работе три вентиля. Поскольку вентиль F, являющийся 
источником данных для выходной линии программы, имеет уп¬ 
равляющий токен TRUE, величина 0 будет просто «поглощена» 
этим вентилем, и таким образом будет предотвращен вывод из 
программы ошибочного результата. То же самое произойдет и 
в вентиле Т, но второй вентиль F формирует величину 2, кото¬ 
рая переведет в состояние готовности расположенный под этим 
вентилем смеситель. Указанный смеситель в свою очередь пере¬ 
шлет величину 2 на смеситель, находящийся вверху слева. Об¬ 
ратите внимание на то, как работает «арифметический раздел» 
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программы. Отказавшись от описания программы как совокуп¬ 
ности процедур и изобразив ее графически, мы сумели отобра¬ 
зить тот факт, что оба арифметических выражения, определен¬ 
ных в операторе IF, могут вычисляться параллельно с вычисле¬ 
нием значения отношения оператора IF (Y>1). Описываемые 
действия завершаются работой вентилей Т и F, осуществляю¬ 
щих выбор нужного вычисленного выражения с целью его пере¬ 
дачи в качестве исходной величины для нового шага итерации. 



Рис. 22.9 показывает состояние программы в один из после¬ 
дующих моментов (третий «мгновенный снимок»). Величина 2 
будет возвращена в результате нового повторения циклическо¬ 
го процесса в левой части графа. Таким образом, действие про¬ 
граммы будет аналогично предыдущему, только изменятся зна¬ 
чения токенов данных. Во время этого выполнения упомянутого 
циклического процесса на выходную линию программы ника¬ 
кие данные помещены не будут. Однако при этом блок приня¬ 
тия решения по критерию «первый операнд отношения больше 
второго» формирует на выходе значение TRUE, что дает воз¬ 
можность входным данным вентиля Т пройти на его выход и 
далее, в верхнюю часть графа. 

Рис. 22.10 иллюстрирует более позднее состояние програм¬ 
мы (четвертый «мгновенный снимок»). В этот момент на выхо¬ 
де блока принятия решения по критерию «первый операнд отно¬ 
шения меньше или равен второму» формируется управляющий 
токен FALSE, рассылаемый четырем адресатам (точкам) про¬ 
граммы. На рис. 22.11 показано соответствующее состояние 
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программы в этот момент времени: на входах вентиля F, рас¬ 
положенного в середине графа, сейчас имеются соответственно 
управляющий токен FALSE и токен данных, значение которого 
равно 4; в результате на выходной линии программы появится 
величина 4. Немаловажно также проследить продвижение пото¬ 
ка остальных токенов по графу программы, поскольку програм¬ 
мы потоков данных имеют одно любопытное свойство: их бло¬ 
ки могут все еще пребывать в состоянии готовности к выпол- 


1Г 
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нению соответствующих функций даже после того, как програм¬ 
ма сформировала требуемый результат. Вентиль F, 
расположенный в левой нижней части, уничтожит оба своих 
входных сигнала, вентиль Т пропустит величину 16, которая 
пройдет через смеситель в верхнюю часть графа, где дальней¬ 
шее продвижение этой величины будет заблокировано, посколь¬ 
ку на вход соответствующего смесителя подается управляющий 
токен ЛОЖНО. Таким же образом окажутся заблокированны¬ 
ми величины 2 и 4, поступающие соответственно на правый и 
средний смесители. 

Следовательно, вскоре после формирования на выходе ре¬ 
зультата программа прекращает функционирование, хотя и не 
произошло ее восстановление в нужное начальное состояние, 
показанное на рис. 22.6. (Граф содержит лишние токены дан¬ 
ных, которых не было вначале.) Это является недостатком про¬ 
граммы, поскольку упомянутые «застрявшие» токены будут 
препятствовать последующим попыткам выполнения этой прог¬ 
раммы. Можно было бы сделать так, чтобы программа сама 
уничтожала такие токены, но для упрощения проводимых рас- 
суждений эти вопросы здесь не рассматриваются. 

Подведем итог тому, что дает такое представление програм¬ 
мы. Оно позволяет достичь высокой степени параллелизма вы¬ 
полнения операций, хотя с точки зрения программиста это не 
является основной целью программирования. Даже в такой 
весьма примитивной программе в каждый момент времени на¬ 
ходилось несколько блоков, одновременно готовых к работе. 
Если предположить реализуемость подобного параллелизма в 
архитектуре вычислительной машины, то можно утверждать, что 
достижима высокая степень распараллеливания вычислений да¬ 
же в небольших программах. Основа такой архитектуры рас¬ 
сматривается в следующем разделе. 

МАШИНА ПОТОКОВ ДАННЫХ 

Перейдем теперь к рассмотрению структуры и архитектуры ти¬ 
пичной машины потоков данных. Такая машина проектируется 
в Массачусетском технологическом институте [4—6, 12—18]. 
Это наиболее известный проект машины, однако уже был выс¬ 
казан ряд других предложений [8, 18—27]. 

Структура этой машины показана на рис. 22.12. Здесь нет 
ни процессора, ни памяти в их традиционном смысле. Машина 
разделена на три главные секции. Первой из них является па¬ 
мять, содержащая ячейки команд. Как будет видно из дальней¬ 
шего рассмотрения, ячейка команды состоит из кода операции, 
одного или более входных портов и указателя ячеек команд, в 
которые должен быть направлен результат выполнения данной 
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блох 

выполнения операции 



Рис. 22.12. Машина потоков данных, проектируемая 
в Массачусетском технологическом институте. 


команды. Ячейки команд не являются пассивными запоминаю¬ 
щими устройствами, они содержат некоторые логические схемы. 

Вторая секция машины включает блоки выполнения опера¬ 
ций и принятия решений. Эти блоки представляют собой устрой¬ 
ства, выполняющие команды. Разница между ними заключает¬ 
ся в том, что результатом работы блока выполнения операции 
являются данные (полученные, например, при реализации опе¬ 
раций сложения или умножения), а результатом работы блока 
принятия решения — управляющая информация (логическая ве¬ 
личина). Как показано, машина потоков данных содержит про¬ 
извольное, насколько возможно большое количество указанных 
блоков. Поскольку их функции заключаются только в том, что¬ 
бы выполнить операцию, условия реализации которой опреде- 
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ляются так называемой селекторной сетью, и послать резуль¬ 
тат в другую сеть, блоки выполнения операций и принятия ре¬ 
шений значительно проще традиционных процессоров. 

Третья секция состоит из трех переключающих сетей. Селек¬ 
торная сеть извлекает команду, готовую к выполнению, форми¬ 
рует так называемый командный пакет и направляет его к 
блоку выполнения операции или принятия решения. Распреде¬ 
лительная сеть принимает пакет результата (данные и адрес 
назначения) и направляет данные в указанную ячейку коман¬ 
ды. Точно так же управляющая сеть передает управляющий па¬ 
кет (результат принятия решения и адрес назначения) в ука¬ 
занную ячейку команды. 


Нод 

операции 

Адрес(а) назначения 

Вентиль¬ 

ной 

вен¬ 

тильный 

флаг 

Шг 
дан - 
иых 

Данные 

Вентиль- 

Sf 

тильныи 

tp/rus 

Іг 

Данные 


Рис. 22.13. Содержимое ячейки команды. 


Машина работает следующим образом. Если ячейка коман¬ 
ды располагает всеми необходимыми входными токенами, она 
посылает командный пакет в селекторную сеть. Последняя на¬ 
правляет пакет к имеющемуся в распоряжении блоку выполне¬ 
ния операции или принятия решения. Порядок перехода команд 
в состояние готовности отличается от порядка, принятого в язы¬ 
ке потоков данных. Дело в том, что в машине для команды 
единственным необходимым условием готовности к выполнению 
является наличие соответствующей входной информации; 
команда может выполняться, даже если занято место, куда дол¬ 
жен поступать формируемый ею результат. В ходе выполнения 
командного пакета создаются один или несколько пакетов ре¬ 
зультата (по одному для каждого адресата), которые пересы¬ 
лаются в распределительную или управляющую сеть. Если 
ячейка назначения пуста, результат переносится в нее. В про¬ 
тивном случае он задерживается в сети до освобождения ячей¬ 
ки назначения. Таким образом, появляется вероятность перегруз¬ 
ки распределительной и управляющей сетей пакетами резуль¬ 
татов, что может привести к неразрешимым —«тупиковым» — 
ситуациям. Оставим на некоторое время в стороне эту пробле¬ 
му и вернемся к ее анализу в одном из последующих разделов. 

Программы потоков данных размещаются в ячейках команд. 
Операция, заданная в команде, соответствует одному из рас- 
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смотренных выше блоков, однако вентили Т и F, а также сме¬ 
ситель и размножитель не имеют явно выраженных эквивален¬ 
тов в наборе команд: их функции могут быть включены во все 
ячейки команд. 

На рис. 22.13 в упрощенном виде представлено размещение 
команды в ячейке. Командой может быть, например, команда 
сложения, состояние готовности которой определяется наличием 
двух входных токенов. 

Содержимое поля «вентильный код», задаваемое для каждого 
входа, определяет вентильные свойства, управляющие приемом 
данных. Ниже приведены четыре возможных значения этого кода: 

N — вентильные функции не выполняются; любой результат, 
направляемый к данному входу, помещается в поле данных 
(разумеется, при условии, что оно свободно); 

Т — данные, направляемые в это поле, будут приняты, если 
управляющий токен TRUE (вентильный флаг) уже поступил 
или поступит в требуемый момент; при значении вентильного 
флага FALSE поступающие данные игнорируются вентилем; 

F — данные, направляемые в это поле, будут приняты, если 
вентильный флаг, имеющий значение FALSE, уже поступил 
или поступит в требуемый момент времени; при значении вен¬ 
тильного флага TRUE поступающие на вентиль данные игнори¬ 
руются; 

С — содержимое поля является константой и не стирается в 
результате выполнения команды. 

Вентильный флаг поступает из управляющей сети и может 
принимать одно из трех значений: 

Off — управляющий пакет (вентильный флаг) не был полу¬ 
чен; 

Т — получен управляющий пакет TRUE; 

F — получен управляющий пакет FALSE. 

Данные поступают из распределительной сети. Флаг дан¬ 
ных указывает, содержит ли порт данные в текущий момент. 

На рис. 22.14 приведено несколько ячеек команд в различ¬ 
ных состояниях. Ячейка на рис. 22.14, а содержит команду сло¬ 
жения (Add), результат выполнения которой должен быть 
направлен в командные ячейки 8а и 22Ь. Обозначение 8а соот¬ 
ветствует первому входному порту, или приемнику, ячейки 8, 
обозначение 22Ь — второму входному порту ячейки 22. При вы¬ 
полнении этой команды сложения произойдет прибавление кон¬ 
станты 1 к принимаемому значению. 

Ячейка на рис. 22.14,6 содержит ту же команду в состоянии 
готовности к выполнению, когда из какой-то другой ячейки по¬ 
ступило значение 2. Звездочкой, расположенной рядом с ячей¬ 
кой, будем отмечать готовые к выполнению команды. После то¬ 
го как командный пакет поступает в селекторную сеть, эта 
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Рис. 22.14. Ячейки команд в различных состояниях. 

ячейка команды восстанавливает свое исходное состояние 
(рис. 22.14,а). 

На рис. 22.14, в показана другая команда сложения. Она на¬ 
правляет результат своей работы во второй входной порт ячей¬ 
ки 6. На один из входов поступает константа, на другой — вен¬ 
тильный код Т. На рис. 22.14, г изображено такое состояние 
ячейки команды, когда управляющий пакет TRUE уже получен 
из другой команды, однако команда еще не готова к выполне¬ 
нию, потому что поле данных пусто. На рис. 22.14, д показано 
другое состояние: ячейка команды получила данные, но еще не 
готова к выполнению, так как не поступил управляющий сигнал 
TRUE. На рис. 22.14, е команда уже готова к выполнению. Пос¬ 
ле выполнения состояние ячейки восстановится в соответствии 
с рис. 22.14, в. 

На рис. 22.14, ж изображено другое возможное состояние: 
ячейка получила управляющий сигнал FALSE. Она останется 
в этом состоянии, пока не поступят данные. В этот момент и 
значение данных, и вентильный флаг F уничтожаются, посколь¬ 
ку коду вентиля присвоено значение Т. Без выполнения коман- 
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ды ячейка вернется в состояние, изображенное на рис. 22.14, в. 

На рис. 22.14,з показана ячейка команды, формирующей уп¬ 
равляющий сигнал. Она принимает два числа и после этого пе¬ 
реходит в состояние готовности к выполнению. Эта команда вы¬ 
полняет проверку отношения указанных чисел на равенство и 
в качестве результата формирует управляющий пакет, содержа¬ 
щий логическую величину TRUE или FALSE. Этот пакет будет 
направлен в позиции вентильных флагов первого входного пор¬ 
та команды 8 и второго входного порта команды 4. 

Рассмотрим теперь работу всей программы. На рис. 22.15 
изображена машинная программа, соответствующая программе 
на языке потоков данных, приведенной на рис. 22.5. Поле флага 
данных здесь не показано, поскольку в последующих рассужде¬ 
ниях отсутствие данных принято обозначать пустым полем дан¬ 
ных. Каждая команда XFER передает указанным в ней адреса- 




Рис. 22.15. Машинная реализация программы, 
представленной на рис. 22.5. 
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Рис. 22.16. Начальное оостояние программы. 


там данные со своего единственного входа, т. е. эта команда 
выполняет функции размножителя. 

Рис. 22.16 показывает программу в исходном состоянии. 
Входная величина Y=0 находится в ячейке 1 (порт а), входная 
величина Х=2 вместе с вентильным флагом TRUE — в ячейке 9 
(порт а), величина 1 —ячейках 10 и 11 (порт а). В рассматри¬ 
ваемый момент времени готовы к выполнению команды яче¬ 
ек 1 и 9. 

Команда ячейки 1 пересылает величину 0 шести адресатам, 
а команда ячейки 9 направляет величину 2 двум адресатам: 
самой себе и в порт b ячейки 11. В результате выполнения этих 
команд данные в ячейке 1, а также данные и вентильный флаг 
в ячейке 9 исчезают. Новое состояние программы показано на 
рис. 22.17. Теперь только одна команда готова к выполнению, 
а именно команда ячейки 11. Некоторые команды (ячейки 2, 
3, 5, 6, 9 и 10) имеют необходимые данные на входе, но ожида- 
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ют поступления одного или нескольких вентильных флагов, пос¬ 
ле получения которых станут готовыми к выполнению. Выпол¬ 
нение команды 11 вызовет появление вентильного флага TRUE, 
который будет доставлен шести адресатам. После этого прог¬ 
рамма окажется в состоянии, показанном на рис. 22.18; теперь 
шесть команд готовы к выполнению. 

При выполнении команд 2, 3, 9 и 10 формируются пакеты 
результатов, подлежащие доставке в соответствующие ячейки. 
В результате выполнения команды 5 создается управляющий 
пакет TRUE, который должен быть доставлен двум адресатам. 
Команда 6 выполняться не будет, поскольку оказывается, что 
хотя она и имеет на входе данные и вентильный флаг TRUE, 
значение ее кода вентиля равно F, и, следовательно, указан¬ 
ные данные и вентильный флаг будут уничтожены. Полагая, что 
все упомянутые команды выполняются параллельно, приходим 
к заключению, что они «поглощают» свои входные данные, в 
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Рис. 22.17. Состояние программы 
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Рис. 22.18. Состояние программы в момент Б. 

результате чего программа переходит в состояние, показанное 
на рис. 22.19. В этот момент готовы к выполнению три коман¬ 
ды. Читатель, наверное, сможет самостоятельно проследить ос¬ 
тавшуюся часть процесса выполнения программы — до того мо¬ 
мента, когда команда ячейки 6 сформирует выходное значение 
и программа перейдет в состояние покоя. 

СЕТИ ТРАКТОВ ПЕРЕДАЧИ ПАКЕТОВ 

Одной из основных проблем в традиционных мультипроцессор¬ 
ных системах является организация связей между запоминаю¬ 
щими устройствами и процесссорами. В машине потоков дан¬ 
ных, рассмотренной в предыдущем разделе, эта проблема раз¬ 
решается путем использования сопрягающих сетей, обладающих 
высокой степенью внутреннего параллелизма функционирова¬ 
ния. Этот параллелизм достигается благодаря тому, что боль- 
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шое количество команд может передавать свои данные через 
сети одновременно. 

Селекторная, распределительная и управляющая сети, пока¬ 
занные на рис. 22.12, представляют собой сети трактов переда¬ 
чи пакетов. Когда команда готова к выполнению, формируется 
пакет операций, посылаемый в селекторную сеть. В функции 
этой сети входит направлять пакеты операций из большого чис¬ 
ла ячеек команд в меньшее число блоков выполнения операций 
и принятия решения, обеспечивая при этом поступление пакета 
к соответствующему блоку. Выполнение команды приводит к 
формированию одного или нескольких пакетов данных или уп¬ 
равляющих пакетов (один пакет для каждого адресата). Эти 
пакеты проходят через распределительную и управляющую сети 
и направляются к указанным ячейкам команд. 

Все три сети могут быть построены на основе элементов 
двух типов (рис. 22.20). Один из них— селектор, передающий 
пакет с одного из своих входов на выход. Селектор обслужива- 




Рис. 22.19. Состояние программы в момент В. 
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ет свои входы по очереди, так что каждый вход рано или позд¬ 
но будет опрошен. Другой элемент — переключатель — направ¬ 
ляет пакет со своего единственного входа на один из выходов, 
при этом выбор нужного выхода производится на основе неко¬ 
торых характеристик пакета. В селекторной сети в качестве 
такой характеристики переключатель использует код операции, 
в распределительной или управляющей сети — адрес пункта на¬ 
значения пакета. Как будет показано ниже, сети включают в 
себя элементы еще трех типов: буферы — для временного хра¬ 
нения информации, а также преобразователи кодов из последо¬ 
вательного в параллельный и из параллельного в последова¬ 
тельный. 



Рис. 22.20. Основные элементы сетей. 


На рис. 22.21 показана функциональная схема простой се¬ 
лекторной сети. Эта небольшая сеть принимает операционные 
пакеты из 16 ячеек команд и направляет их к четырем процес¬ 
сорам. Селекторную сеть можно представить себе в виде черно¬ 
го ящика с большим количеством входов (по одному на каждую 
ячейку команды) и меньшим количеством выходов (по одному 
на процессор). Вследствие большого количества входов возника¬ 
ет проблема минимизации числа соединений между селекторной 
сетью и памятью команд. Поэтому указанная сеть принимает 
информацию из ячеек команд в виде последовательности битов. 
В то же время со стороны выходов желательно минимизировать 
время, в течение которого процессор занят выполнением 
команд, и, следовательно, целесообразно передавать пакет в 
процессор весь сразу. Таким образом, в процессе прохождения 
пакетов команд по селекторной сети осуществляется преобразо¬ 
вание информации пакетов из последовательного кода в парал¬ 
лельный. 

Параллелизм функционирования сети возможен благодаря 
использованию буферов, обеспечивающих временное хранение 
командных пакетов на входах каждого переключателя и селек¬ 
тора. Так, в небольшой селекторной сети, показанной на 
рис. 22.21, могло бы находиться до 30 пакетов команд. Селек¬ 
торы и переключатели функционируют асинхронно, поэтому 
асинхронно и продвижение пакетов через сеть, за исключением 
случаев «конкуренции». 
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Управляющая и распределительная сети строятся на тех же 
элементах, что и селекторная сеть, но отличаются от послед¬ 
ней конфигурацией схемы соединения этих элементов 
(рис. 22.22). Распределительная и управляющая сети имеют 
малое количество входов и большое количество выходов. По 
причинам, рассмотренным выше, эти сети получают пакеты в 
параллельном коде, а затем по мере их прохождения выполня¬ 
ют преобразование параллельного кода в последовательный, в 



результате чего в ячейки команд пакеты поступают в виде по¬ 
следовательности битов. 

Если проследить порядок прохождения пакета в схемах на 
рис. 22.21 или 22.22, то можно сделать заключение, что суще¬ 
ствует только один возможный путь из определенного входа в 
заданный выход. Однако в больших сетях возможно отступле¬ 
ние от этого правила. 

Анализ времени, необходимого для выполнения команды, 
показывает, что оно является суммой временной задержки пре¬ 
бывания команды в селекторной сети, времени выполнения 
команды в процессоре и временной задержки в рапределитель- 
ной или управляющей сети. Время работы процессора фикси¬ 
рованно, а задержки в сетях носят стохастический характер. 
Эти задержки являются функцией количества уровней в сети 
и числа других пакетов в этой сети. Поскольку число пакетов в 
сети в каждый момент времени зависит от особенностей конк- 



Рис. 22.22. Организация небольшой распределительной 
сети. 


ретной программы, анализ производительности представляет 
собой непростую задачу. 

Продвижение пакетов через сеть может увеличить суммар¬ 
ное время выполнения каждой отдельной команды (до десят¬ 
ков микросекунд), но это не обязательно приведет к заметному 
снижению производительности машины, поскольку в движении 
одновременно находится большое число пакетов. Длительность 
продвижения становится «узким местом» только в тех случаях, 
когда готовым к выполнению оказывается лишь небольшое чис¬ 
ло команд. (Предположим, программа достигла состояния, ког¬ 
да готова к выполнению только одна команда.) Например, ес¬ 
ли в машине 20 процессоров — блоков выполнения операций и 
принятия решения, — каждый из которых может обработать 
командный пакет в среднем за 200 нс, то в целом производи¬ 
тельность машины может быть оценена быстродействием, рав¬ 
ным 100 млн. операций в секунду. Такая скорость достижима 
даже в условиях чрезвычайно медленного прохождения отдель¬ 
ного пакета по сетям, если в любой момент времени найдется 
по меньшей мере 20 готовых к выполнению команд, если селек¬ 
торная сеть может поставлять 20 командных пакетов каждые 
200 нс и если распределительная и управляющая сети облада¬ 
ют примерно такими же возможностями. Последнее необходи- 



АРХИТЕКТУРА МАШИН, УПРАВЛЯЕМЫХ ПОТОКОМ ДАННЫХ 245 


мо для того, чтобы поддерживать максимальное число готовых 
к выполнению команд. 

Из рассмотренного выше можно сделать интересный вывод, 
что сети трактов передачи пакетов моделируют основные прин¬ 
ципы функционирования машин потоков данных на физическом 
уровне; сами сети могут рассматриваться как программы на 
языке потоков данных или как сети Петри. Таким образом, на¬ 
лицо два уровня параллелизма вычислений. Один уровень оп¬ 
ределяется наличием множества команд, одновременно готовых 
к выполнению и доступных для параллельной обработки многи¬ 
ми процессорами. Другой, нижний уровень определяется про¬ 
хождением этих команд и их результатов через сети, которые 
сами в большой степени обладают свойством параллелизма 
функционирования. 

Еще одним свойством машин потоков данных, которое теперь 
становится очевидным, является высокая степень однородности 
логической структуры машины. Уже ячейка команды содержит 
значительную часть различных элементов, определяющих струк¬ 
туру машины в целом. Каждая ячейка включает запоминающее 
устройство и логические схемы проверки состояния готовности 
команды к выполнению. Другой формой проявления однородно¬ 
сти логической структуры машины потоков данных является 
наличие большого количества блоков выполнения операций и 
принятия решений. И наконец, только что было показано, что 
сетям трактов передачи пакетов также присуща высокая сте¬ 
пень однородности структуры, поскольку они состоят из боль¬ 
шого числа селекторов, переключателей, буферов и преобразо¬ 
вателей. Существуют проекты, которые идут еще дальше в осу¬ 
ществлении этого принципа и демонстрируют способ построения 
сети из маршрутных модулей 2X2 вместо переключателей и се¬ 
лекторов [28, 32]. Подобная однородность логической структуры 
машин потоков данных делает принципы их организации осо¬ 
бенно привлекательными при широком внедрении сверхбольших 
интегральных схем, применение которых в свою очередь расши¬ 
ряет возможности по выбору той или иной конфигурации ма¬ 
шины. 


ПЕРЕПОЛНЕНИЕ 
И ТУПИКОВЫЕ СИТУАЦИИ 

В машине потоков данных, описанной в предыдущем разделе, 
перевод команд в состояние готовности к выполнению произво¬ 
дится независимо от того, доступны или нет их адресаты. Та¬ 
ким образом, команда может быть выполнена и один или не¬ 
сколько пакетов результата посланы в распределительную сеть 
до того, как команды-получатели будут способны принять их. 
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Первой проблемой, по¬ 
рождаемой такими принци¬ 
пами работы машины, мо¬ 
жет оказаться перегрузка 
распределительной и управ¬ 
ляющей сетей. Пакет ре¬ 
зультата, находящийся в 
распределительной сети, 
размещается в буфере, свя¬ 
занном с соответствующим 
селектором или переключателем. Этот пакет будет препятство¬ 
вать продвижению последующих пакетов через данный участок 
сети до тех пор, пока находится там. Большое число пакетов, 
пребывающих в таком состоянии, может привести к блокиров¬ 
ке движения в сети. 

Второй проблемой является возможность возникновения ту¬ 
пиковых ситуаций. Тупиковая ситуация имеет место в том слу¬ 
чае, если пакет результата А задерживает пакет результата В, 
в то время как пакет В необходим для перевода в состояние го¬ 
товности той самой команды, для которой предназначен и к ко¬ 
торой направлен пакет А. Такая ситуация показана на 
рис. 22.23. Допустим, что команда 3 не переводится в состояние 
готовности, поскольку данные поступили в порт ЗЬ и не посту¬ 
пили в порт За. Допустим также, что некоторый пакет А нахо¬ 
дится в состоянии ожидания в переключателе, так как пунктом 
его назначения является порт ЗЬ. Следовательно, пакет А бу¬ 
дет задерживать движение всех остальных пакетов через этот 
переключатель. Где-то в распределительной сети находится 
пакет В, направляемый в порт За. Однако он никогда не смо¬ 
жет достичь пункта назначения. Создалась тупиковая ситуация. 

Обе указанные проблемы решаются путем введения сигналов 
обратной связи между блоками выполнения операций [4, 29]. 
В дополнение к ранее определенным видам линий связи введем 
еще один вид — сигнальные линии. Сигнальная линия обозна¬ 
чается пунктиром и используется для передачи сигнала под¬ 
тверждения от одного блока выполнения операций к другому, 
предыдущему. Этот сигнал вырабатывается блоком специаль¬ 
ного вида, называемым сигнальным блоком (рис. 22.24). Сиг¬ 
нальный блок переводится в состояние готовности, когда на 
его входную линию подается токен любого вида — либо токен 
данных, либо управляющий токен. Блок „поглощает” такой то¬ 
кен; при этом формируется сигнал подтверждения на выходной 
линии блока. Описанные выше блоки должны быть модифици¬ 
рованы таким образом, чтобы сигнал обратной связи использо¬ 
вался в качестве дополнительного входного сигнала. Пример 
модификации функционального блока представлен на рис. 22.24. 


Ячейки 

команд 



Рис. 22.23. Тупиковая ситуация 
в распределительной сети. 
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Здесь показан блок с тремя входами: две обычные линии дан¬ 
ных и сигнальная линия. Блок переводится в состояние готов¬ 
ности к выполнению, если токены данных поступили на вход¬ 
ные линии данных, а сигнальный токен — на сигнальную линию. 
Блок «поглощает» входную информацию, выполняет необхо¬ 
димые преобразования данных и формирует результат в виде 
токена данных. 

В некоторых случаях объектом функциональных преобразо¬ 
ваний может служить сам сигнал обратной связи. Блок OR 
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Рис. 22.24. Блоки, оперирующие сигналами 
подтверждения. 

(ИЛИ), показанный на рис. 22.24, переводится в состояние го¬ 
товности, когда упомянутый сигнал подается на любую из его 
входных линий. Сигнал поступает в блок и выдается на выход¬ 
ной линии. Блок совпадения (JUN) переводится в состояние 
готовности, когда сигнальные токены присутствуют на всех его 
входных линиях. Он «поглощает» эти сигналы и формирует сиг¬ 
нал на выходной линии. 

Сигналы обратной связи применяют для предотвращения 
тупиковых ситуаций следующим образом. Каждый блок, кото¬ 
рый в принципе может выдать несколько токенов на свою вы¬ 
ходную линию (т. е. может выполнить свою операцию неодно¬ 
кратно), преобразуют в подобный же блок вентильного типа, 
управляемый сигналом обратной связи с выхода следующего за 
ним блока (или блоков). Если результат операции, выполняе¬ 
мой данным блоком, посылается в несколько пунктов назначе¬ 
ния, для формирования общего сигнала подтверждения о до¬ 
ступности всех адресатов может использоваться блок совпаде¬ 
ния. 



На рис. 22.25 представлен 
простой пример такого реше¬ 
ния. Здесь при выполнении 
операции сложения формиру¬ 
ется сигнал подтверждения, 
который посылается обратно в 
блок или блоки — источники 
входных данных для данного 
блока, реализующего опера¬ 
цию сложения. Блок операции 
умножения возвращает сигнал 
подтверждения блоку опера¬ 
ции сложения. Блок, которо¬ 
му передается результат умно¬ 
жения, в свою очередь выдаст 
сигнал подтверждения. 

Манипулирование сигнала¬ 
ми обратной связи может 
быть предусмотрено в сущест¬ 
вующем наборе машинных 
команд без введения для этих 
целей дополнительных команд. На рис. 22.26 показана команда 
ADD, по которой производится сложение переданного ей значе¬ 
ния данных с константой 3. Команда претерпела следующие 
изменения. Во-первых, в поле, следующем за полем кода опе¬ 
рации, указывается количество сигнальных пакетов, которые 
должны быть получены командой для ее перевода в состояние 
готовности к выполнению. Если это поле содержит 0, то коман¬ 
да не обладает вентильными свойствами и может быть приве¬ 
дена в состояние готовности к выполнению сразу же по получе¬ 
нии токена данных. Если же в поле находится 1, то для пере¬ 
вода команды в состояние готовности ей необходимы и посыл¬ 
ка данных, и сигнал подтверждения. Команды, которые в этом 
поле содержат числа больше чем 1, обладают возможностями 
встроенной схемы совпадения. Команде ADD, показанной на 
рис. 22.26, для перевода в состояние готовности необходимо 
поступление двух сигнальных пакетов. 

Во-вторых, еще одно дополнительное поле в команде отве¬ 
дено под указатель количества полученных к текущему момен¬ 
ту сигналов обратной связи. Когда значение содержимого этого 
поля становится равным 2 и поступает пакет данных, команда 
готова к выполнению. После «поглощения» пакета данных со¬ 
держимому этого поля присваивается нулевое значение. 

В-третьих, модифицировано указание адресатов команды. 
Теперь адреса, по которым посылается результат выполнения 
команды, помечаются символическими метками D и S, как по- 



Рис. 22.25. Пример использования 
сигналов подтверждения. 
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казано на рис. 22.26. Пакеты результатов выполнения этой 
команды будут направлены в ячейки команд 8а и 9Ь, а сигнал 
подтверждения — в ячейку 4. 

Формирование сигнальных пакетов может быть реализовано 
достаточно просто. Для их генерирования не требуется ожидать 
завершения выполнения команды. Сигнал может быть сформи¬ 
рован, как только команда становится готовой к выполнению 
и извлекается селекторной сетью, поскольку с этого момента 
ячейка команды доступна для новых входных данных. Следова¬ 
тельно, указанная сеть может прежде всего проверить, должен 


Рис. 22.26. Ячейка команды, 
рассчитанная на операции с сигналами 
подтверждения. 


ли данный командный пакет в результате выполнения выда¬ 
вать сигнальный пакет (или пакеты). При необходимости сиг¬ 
нальный пакет может быть сразу сформирован селекторной 
сетью и направлен в управляющую сеть для пересылки соответ¬ 
ствующему адресату. 


ОБРАБОТКА СТРУКТУР ДАННЫХ 


До сих пор за пределами рассмотрения оставался вопрос о том, 
каким образом программы потоков данных оперируют совокуп¬ 
ностями данных, такими, как массивы или структуры. Очевид¬ 
но, что использование для этой цели многозначных токенов не¬ 
удобно, если массивы или структуры имеют значительные раз¬ 
меры. Перемещение длинных векторов сквозь селекторную и 
распределительную сети во время обработки является весьма 
нежелательным. 

Один из вариантов решения этой проблемы предусматрива¬ 
ет, во-первых, введение в машину потоков данных дополнитель¬ 
ной памяти, предназначенной для хранения не команд, а струк¬ 
тур данных, и во-вторых, создание средств адресации этой па¬ 
мяти. Прежде чем перейти к вопросу физической реализации 
указанного подхода, рассмотрим типы структур данных и свя- 
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занные с ними блоки [5, 30, 31]. В языке потоков данных опре¬ 
делены три типа данных: 

«Пусто» Отсутствие данных 

Элементарные данные Данные скалярного типа или управ¬ 
ляющая информация 

Структура Упорядоченная совокупность данных 

любого из трех типов 


Упрощенно структуру можно изобразить в виде двоичного 
дерева, в котором каждый элемент — узел — представляет дан¬ 
ные типа «пусто», элементарные данные или структуру. На 
рис. 22.27 представлена структура по имени S, размещенная в 
пассивной памяти данных. 

Для адресации к любому элементу структуры необходимо 


S 



3,6 7 4,2 Отсутствие данных 

Рис. 22.27. Пример 
представления структуры. 


указать ее имя и двоичную последо¬ 
вательность переменной длины, кото¬ 
рая определяет маршрут поиска на 
двоичном дереве (0 соответствует ле¬ 
вой ветви, а 1—правой). Примени¬ 
тельно к дереву, показанному на 
рис. 22.27, адрес S,1 ссылается на 
узел, содержащий величину 6,2. Ад¬ 
рес S.000 ссылается на величину 3,6- 
Адрес S,00 определяет двухэлемент¬ 
ную подструктуру, содержащую вели¬ 
чины 3,6 и 7. 

Для выполнения операций над 
структурами вводятся четыре новых 
блока. Первый из них — блок выбора. 
Он имеет две входные линии: для 
имени (адреса) структуры и для дво¬ 


ичной строки. В результате работы блока выбора определяется 


значение элемента (узла) структуры, соответствующего указан¬ 


ному имени структуры и заданному местоположению этого эле¬ 
мента. Если в узле содержатся элементарные данные, то на 
выходной линии блока появляется значение этих данных. Если 
же узел является структурой (именуемой в этом случае под¬ 
структурой), то блок выбора выдает на выходную линию имя — 
адрес подструктуры. При подаче на входы блока выбора зна¬ 
чения S и величины 010 (см. рис. 22.27) на выходе блока по¬ 
явится величина 4,2. 

Вторым новым блоком, вводимым для обработки структур, 
является блок добавления, который служит для введения новых 
элементов в существующую структуру. Блок добавления имеет 
три входа, два из них такие же, как и у блока выбора, а тре¬ 
тий используется для передачи в блок значения вводимого в 
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Ѵис. 22.28. Машина потоков данных, обрабатывающая структуры. 

структуру элемента или адреса подсоединяемой структуры. На 
основании данных, поступающих на первые два входа, блок до¬ 
бавления находит нужный узел в дереве структуры. Содержи¬ 
мое этого узла заменяется данными, поступающими на третий 
«ход. Так, при поступлении на входы блока добавления дан¬ 
ных S, 010, 4,3 (где S соответствует рис. 22.27) значение 4,2 
будет заменено на 4,3. Если на третий вход блока добавления 
подать адрес структуры, то последняя станет узлом исходной 
структуры. 

Третьим новым блоком, вводимым для обработки структур, 
является блок удаления, имеющий два входа, на один из кото¬ 
рых подается имя структуры, а на другой—двоичная строка. 
Адресуемый узел «стирается», т. е. ему присваивается значение 
«пусто». Предусмотрен также блок построения, который на ос¬ 
новании двух входных данных (элементарных данных или 
структур) строит новую структуру, содержащую в качестве эле¬ 
ментов входные данные. В результате работы блока на его вы¬ 
ходной линии появляется адрес новой структуры. 


97* 




На рис. 22.28 представлена обобщенная схема машины по¬ 
токов данных, в которую введено устройство хранения и обра¬ 
ботки структур. Когда селекторная сеть обнаруживает наличие 
операционного пакета, предназначенного для одного из блоков 
обработки структур, она передает этот пакет в устройство хра¬ 
нения и обработки структур. На выходе этого устройства по¬ 
явятся (в зависимости от типа блока) один или несколько па¬ 
кетов результата, которые будут направлены в распределитель¬ 
ную сеть. 

На рис. 22.29 представлена схема устройства хранения и об¬ 
работки структур. Для пояснения принципа его функциониро¬ 
вания рассмотрим несколько примеров. Когда функционирует 
блок выбора, селекторная сеть направляет операционный пакет 
в распределительную сеть устройства. Адрес структуры в 
команде выбора дает возможность извлечь слово из памяти 
хранения структур. Если значение слова определяет структуру, 
а не элементарные данные, то с помощью первого бита в двоич¬ 
ной строке, являющейся операндом для блока выбора, выби¬ 
рается один из двух адресов подструктур, относящихся к дан¬ 
ному узлу структуры. Этот адрес вместе с остатком двоичной 
строки помещается в новый пакет выбора и через селекторную 
сеть направляется вновь в распределительную сеть. Таким об- 



Рис. 22.29. Устройство хранения н обработки структур. 
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разом, в результате выполнения операции выбора может быть 
сформирована последовательность новых запросов на опера¬ 
цию выбора. Эти запросы последовательно обрабатываются па¬ 
мятью структур до тех пор, пока не встретится узел, содержа¬ 
щий элементарные данные. После этого формируется и выдает¬ 
ся пакет, содержащий найденные элементарные данные и адрес 
пункта назначения, указанный в исходной команде выбора. 

Другие операции над структурами выполняются одним или 
несколькими блоками обработки структур данных. Эти блоки 
оперируют содержимым памяти структур путем формирования 
запросов на обращение к памяти с целью извлечения ее содер¬ 
жимого или записи данных на хранение. Эти запросы имеют 
тот же формат, что и пакет запроса на операцию выбора, и так 
же направляются через распределительную сеть памяти струк¬ 
тур. Результат, извлеченный из памяти структур, опять направ¬ 
ляется в блок обработки структур. В конечном счете формиру¬ 
ется пакет результата, который передается в общую распреде¬ 
лительную сеть машины потоков данных. 

УПРАЖНЕНИЯ 

22.1. Модифицируйте программу потоков данных, представленную на 
рис. 22.6, таким образом, чтобы после получения результата осуществлялся 
возврат в исходное состояние. (Для этого необходимо ликвидировать «за¬ 
стрявшие» токены данных в соответствии с описанием рис. 22.11.) 

22.2. Проследите ход выполнения программы, показанной на рис. 22.19, 
до ее завершения. Ответьте на следующие вопросы: произойдет ли останов 
программы после получения результата? Восстановит ли программа свое на¬ 
чальное состояние? Если начальное состояние не восстановится, предложите 
меры по корректировке программы, которые обеспечат выполнение этой про¬ 
цедуры. 

22.3. Модифицируйте программу, представленную на рис. 22.15, используя 
для предотвращения тупиковых ситуаций сигналы обратной связи. 

22.4. Каковы результаты выполнения команд SELECT S,00,X и 
APPEND S,101,X, где X представляет собой линию между командой SELECT 
(ВЫБОР) и командой APPEND (ДОБАВЛЕНИЕ), а структура S соответст¬ 
вует изображенной на рис. 22.27. 
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ЧАСТЬ VIII 

ВОПРОСЫ, СВЯЗАННЫЕ 
С АРХИТЕКТУРОЙ СИСТЕМ 


Г Л А В А 23 

ОПТИМИЗАЦИЯ И НАСТРОЙКА 
АРХИТЕКТУРЫ ВЫЧИСЛИТЕЛЬНОЙ СИСТЕМЫ 

По завершении разработки первоначального проекта архитек¬ 
туры вычислительной системы необходима оптимизация ее ниж¬ 
него уровня, осуществляемая методами теории информации. Ко¬ 
нечно, сам выбор варианта построения архитектуры можно рас¬ 
сматривать как процесс оптимизации. Здесь же речь идет об 
оптимизации нижнего уровня, т. е. о такой настройке архитек¬ 
туры, при которой удается минимизировать количество битов, под¬ 
лежащих пересылке между процессором и памятью при выпол¬ 
нении заданной программы. Благодаря этому удается сократить 
объем необходимой памяти, уменьшить время выполнения про¬ 
грамм за счет более эффективного использования тракта па¬ 
мять-процессор и —как полезный побочный эффект — отказать¬ 
ся от в определенном смысле произвольных ограничений на 
предельные значения кодов операций и адресов. 

Оптимизация нижнего уровня сводится к отысканию наибо¬ 
лее эффективного метода кодирования информации. Существу¬ 
ют три основных подхода к решению этой проблемы: усовер¬ 
шенствование существующего набора команд путем введения в 
него новых команд, оптимизация представления отдельных ком¬ 
понентов команд (кодов операций, адресов, ссылок на операн¬ 
ды, данных) и оптимизация всей формы представления команды. 
Для успешного выполнения указанной оптимизации необходи¬ 
ма детальная информация о характеристиках программ, вклю¬ 
чающая относительную частоту выполнения отдельных машин¬ 
ных команд и их сочетаний (например, зависимость выполнения 
одних команд от других или вероятность того, что после коман¬ 
ды LOAD будет выполняться команда ADD) и относительную 
частоту присвоения переменным и адресам определенных зна¬ 
чений. На первый взгляд может показаться, что единственным 
путем получения этих сведений является создание (физическая 
реализация) или моделирование машины, составление программ 
для этой машины с их последующим компилированием и изме- 
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рением искомых параметров этих программ. Однако далее бу* 
дет показано, что необходимую информацию можно обеспечить 
без разработки машины и компиляторов, служащих для генери¬ 
рования ее машинных программ. 

Проблема сбора указанной информации осложняется тем, 
что возможны два подхода к измерению упомянутых выше час¬ 
тот: статический и динамический. Например, сведения о часто¬ 
те использования команд определенного типа в программе мо¬ 
гут быть получены путем подсчета количества команд, разме¬ 
щенных в памяти или генерируемых компилятором. В результа¬ 
те будет определена статическая частотная характеристика про¬ 
граммы. Если эти данные использовать как исходные для про¬ 
цесса оптимизации проектируемой архитектуры, то этот процесс 
окажется ориентированным на сокращение требуемого объема 
памяти, но при этом не обязательно уменьшение времени вы¬ 
полнения программ. Следует, однако, учитывать тот факт, что 
сокращение рабочего пространства памяти, занятого програм¬ 
мой, во многих ЭВМ приводит косвенно и к уменьшению време¬ 
ни выполнения. Кроме того, можно получить данные о частоте 
появления различных команд путем их подсчета во время вы¬ 
полнения. Такие частотные зависимости называются динамичес¬ 
кими. Используя их в качестве исходных данных процесса оп¬ 
тимизации, можно определить выигрыш во времени выполнения 
программ, но не в объеме занимаемой ими памяти. 

Казалось бы, что в каждом случае необходимо делать выбор 
только одного из параметров — времени выполнения программы 
или объема занимаемой памяти — в качестве критерия оптими¬ 
зации. В действительности такая дилемма возникает редко. 
Многочисленные статистические данные указывают на тесную 
взаимосвязь статических и динамических частотных характери¬ 
стик программ, что позволяет выбрать в качестве основы оп- 

Таблица 23.1. Статическая и динамическая 

характеристики наиболее часто используемых команд 

Системы 360 


Команда 

явления 
команды, % 

Команда 

ская частота 
появления 
команды, % 

L 

28,6 

L 

27,3 

ST 

15,0 

ВС 

13,7 

ВС 

10,0 

ST 

9,8 

LA 

7,0 

с 

6,2 

SR 

5,8 

LA 

6,1 

BAL 

5,3 

SR 

4,5 

SLL 

3,6 

ІС 

4,1 

ІС 

3,2 

А 

3,7 
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тимизации в каждом отдельном случае ту или другую характе¬ 
ристику и получить выигрыш сразу по двум критериям: времени 
выполнения программ и занимаемой ими памяти. В качестве 
наглядного подтверждения сказанному в табл. 23.1 по резуль¬ 
татам анализа 19 программ приведены статические и динами¬ 
ческие характеристики, определяющие частоту появления вось¬ 
ми наиболее часто используемых машинных команд Системы 
360 [1]. 


ОПТИМИЗАЦИЯ СИСТЕМЫ КОМАНД 

Одно из возможных решений подобной оптимизации сводится 
к анализу использования в программах существующих машин¬ 
ных команд с целью создания новых команд, обеспечивающих 
сокращение времени выполнения программ и объема занимае¬ 
мой ими памяти. В основу такого решения положено измере¬ 
ние частоты появления одного и того же сочетания следующих 
одна за другой двух или трех команд и создание одной коман¬ 
ды, выполняющей те же функции и, следовательно, способной 
заменить эту группу команд. 

В качестве примера рассмотрим следующую пару команд 

SR регистр,регистр 
ІС регистр,адрес 

которая, как оказалось, встречается довольно часто в програм¬ 
мах Системы 360 (статическая частота ее использования равна 
2,7%, динамическая — 3,8% среди всех пар команд). Коман¬ 
да SR (ВЫЧИТАНИЕ регистровое) производит очистку реги¬ 
стра, а по команде ІС (ЗАГРУЗКА СИМВОЛА в регистр) в 
регистр помещается величина, соответствующая представлению 
символа в памяти. Для улучшения состава набора команд мож¬ 
но было бы создать новую команду ОЧИСТКА РЕГИСТРА И 
ЗАГРУЗКА СИМВОЛА, занимающую меньший объем памяти 
и выполняемую быстрее, чем пара команд SR -ІС. Можно ожи¬ 
дать, что такое тривиальное усовершенствование набора 
команд уменьшит размер программы в среднем на 1%, а время 
ее выполнения — на 1,5%. 

Рассмотрим еще один пример. Анализ программ для Систе¬ 
мы 370 показал, что компилятор часто генерирует следующую 
последовательность команд: 

ST REG,SAVE 
L REG,VARIABLE 

LA REG, N(, REG) 

ST REG,VARIABLE 

L REG,SAVE 
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Эти команды предназначены для увеличения значения пере¬ 
менной целого типа VARIABLE на величину N. Поскольку в 
данной машине операции двоичной арифметики выполняются 
только над содержимым регистров, а число регистров невели¬ 
ко, требуется включение двух пар команд, обеспечивающих за¬ 
грузку регистра и запись его содержимого в память. В моде¬ 
ли 145 Системы 370 суммарное время выполнения этих команд 
равно 8,8 мкс, и они занимают 20 байт памяти. Если ввести 
новую команду INCREMENT, имеющую формат 
INC VARIABLE,INCREMENT-VALUE 

где INCREMENT-VALUE — приращение переменной 

VARIABLE, то она могла бы заменить все пять команд. Для 
размещения этой команды в памяти потребовалось бы 4 байт, 
ориентировочное время ее выполнения составило бы 2,7 мкс. 
Внимательный читатель может возразить, что посредством 
команды LA числовую величину можно увеличить на 4095, а с 
помощью команды INC — только на 16. Однако анализ частоты 
выполнения в программах различных подобных приращений 
показывает, что команда INC оказалась бы применимой в по¬ 
давляющем большинстве случаев. 

В машинах, построенных с использованием других архитек¬ 
турных принципов, могут быть обнаружены аналогичные ситуа¬ 
ции. Например, в ЭВМ со стековой организацией часто прихо¬ 
дится выполнять последовательность команд 

PUSH VARIABLE 

PUSH 1 

ADD 

! STORE VARIABLE ] 

Добавление не использующей стек команды 
INCREMENT VARIABLE 

дало бы очевидный выигрыш и во времени выполнения, и в 
объеме памяти. 


ОПТИМИЗАЦИЯ КОМАНД УЧЕБНОЙ ПЛ-МАШИНЫ 

Первоначальным и основным назначением учебной ПЛ-машины 
было использование ее как «инструмента» освоения техники 
оптимизации архитектуры вычислительной системы [3]. В гл. 
5—7 описан «неоптимизированный» вариант этой машины; в 
данной главе рассматриваются некоторые пути усовершенство¬ 
вания ее архитектуры. 

В качестве исходных данных для оптимизации использова¬ 
лись статистические характеристики 959 программ, прошедших 
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компилирование для выполнения на «неоптимизированном» ва¬ 
рианте машины. Общее количество проанализированных опера¬ 
торов учебного языка ПЛ составило 37 443. Результат каждого 
изменения, вносимого в архитектуру оптимизируемой машины, 
количественно оценивался следующими показателями: 

А1 — число битов в командах программы; 

А2 — число битов в данных программы; 

АЗ — число адресных ссылок к памяти при обращении к 
командам; 

А4 — число адресных ссцлок к памяти при обращении к 
данным; 

А5 — число битов команд, извлекаемых из памяти в процес¬ 
се выполнения программы; 

А6 —число битов в данных, извлекаемых из памяти в про¬ 
цессе выполнения программы. 

Первым шагом анализа было определение частотных харак¬ 
теристик команд. Динамические и статические характеристики 
наиболее часто используемых команд приведены в табл. 23.2. 
(Команда NAME представляет команды SNAME и LNAME.) 

Первым усовершенствованием, внесенным в рассматривае¬ 
мую архитектуру, было изъятие команды LINE. Поскольку со¬ 
ответствие между машинной командой и номером оператора 
языка программирования носит статический характер, нет необ¬ 
ходимости в постоянном аппаратном отслеживании этого соот¬ 
ветствия в процессе выполнения программы. Вместо такого 
отслеживания можно воспользоваться информацией, содержа¬ 
щейся в формируемой программными средствами таблице со¬ 
ответствия выполняемых машинных команд и номеров операто¬ 
ров исходной программы, находящейся во внешней памяти. Эта 
простая модификация исходной архитектуры уменьшила в сред¬ 
нем показатель А1 на 14%, АЗ на 8,7 % j и А5 на 12,2%. 


Таблица 23.2. Статическая 
и динамическая характеристики 
наиболее часто используемых команд 
учебной ПЛ-машины 


Команда 

Статическая 
частота по¬ 
явления 
команды, % 

Динамиче¬ 
ская частота 
появления 
команды, % 

NAME 

30,3 

28,3 

EVAL 

20,7 

23,7 

LINE 

10,0 

8,7 

SWAP 

4,8 

4,1 

POP 

4,8 

2,7 


Таблица 23.3. Наиболее часто 
используемые пары команд учебной 
ПЛ-машины 


Пары команд 

Статическая 
частота по¬ 
явления па¬ 
ры команд, % 

NAME, EVAL 

19,8 

NAME, NAME 

8,9 

EVAL, NAME 

6,5 

PARAM, SWAP 

4,1 

POP, NAME 

3,6 

STORE, POP 

3,3 
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Следующим шагом анализа возможностей усовершенствова¬ 
ния архитектуры являлось изучение частоты совместного ис¬ 
пользования пар команд. Статическая частота совместного ис¬ 
пользования шести наиболее употребительных пар показана 
в табл. 23.3. 

Часто применяемые совместно команды NAME и EVAL слу¬ 
жат для загрузки той или иной величины на вершину стека. 
Очевидное улучшение архитектуры машины достигается вклю¬ 
чением в существующий набор команд команды SLOAD (ЗА¬ 
ГРУЗКА короткая), выполняющей функции указанной пары, 
для замены пары команд SNAME и EVAL и команды LLOAD 
(ЗАГРУЗКА длинная) для замены пары команд LNAME и 
EVAL. Тогда вместо пары команд 

SNAME 1,3 

EVAL 

предназначенных для загрузки переменной с адресом 1,3 на 
вершину стека, компилятор генерирует команду 
SLOAD 1,3 

Добавление команд SLOAD и LLOAD уменьшает показа¬ 
тель А1 в среднем на 23%, а также снижает значение показа¬ 
телей АЗ и А5. Заметим, что хотя команды LOAD добавляются 
к набору команд машины, команды SNAME, LNAME и EVAL 
из него не изымаются, поскольку существуют ситуации, в ко¬ 
торых необходимо использование каждой из них порознь. 

Затем были произведены еще четыре подобные модифика¬ 
ции архитектуры учебной ПЛ-машины. Было обнаружено, что 
в 72% случаев использования команды STORE за ней следует 
команда POP. Поэтому была добавлена новая команда 
STORED, выполняющая функции пары команд STORE и POP. 
Точно так же, согласно статистическим данным, в 71% слу¬ 
чаев за командой SUBS следовала команда EVAL, что привело 
к введению команды SUBSEVEL. Дальнейший анализ пар 
команд показал, что за каждой командой DOTEST следует 
команда CRET, а за каждой командой DOINCR — команда 
CYCLE. В соответствии с этим выводом команды DOTEST и 
DOINCR были модифицированы таким образом, чтобы вклю¬ 
чить в себя функции команд CRET и CYCLE. 

Затем усилия по улучшению архитектуры учебной ПЛ-ма¬ 
шины были направлены на анализ возможностей средств адре¬ 
сации. Выяснилось, что среди команд типа NAME (SNAME и 
LNAME) 72,7% составляют команды SNAME. Целью оптими¬ 
зации было увеличение процента использования команд 
SNAME, а также уменьшение длины команд SNAME и 
LNAME. 
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Прежде всего был проведен частотный анализ распределе¬ 
ния адресов по лексическим уровням. Согласно результатам; 
исследования [1], во-первых, более 80% всех адресов в коман¬ 
дах ссылаются на внешний лексический уровень (лексический; 
уровень 1, как и уровень 0, использовался в системных целях) 
и, во-вторых, более 90% адресов в командах конкретного лек¬ 
сического уровня являются обращениями к тому же лексичес¬ 
кому уровню, т. е. большинство ссылок указывает на локаль¬ 
ные переменные текущего уровня. 

Указанные выше причины, а также неполное использование 
8-битового поля кода операции (количество типов команд ме¬ 
нее 256), явились основанием для внесения четырех изменений 
в учебную ПЛ-машину. Длина команды SNAME была умень¬ 
шена до 8 бит. 

Вместо того чтобы, как это принято для всех команд, ис¬ 
пользовать для кода операции все 8 бит, полагают, что равен¬ 
ство нулю первой пары этих битов является признаком того*, 
что данная команда — команда SNAME. Остальные 6 бит ин¬ 
терпретируются следующим образом. Если команда SNAME 
принадлежит лексическому уровню 1, то адресуемым лексичес¬ 
ким уровнем считается уровень 1, а 6 бит — порядковым номе¬ 
ром (0—63) адресуемого операнда этого уровня. Если коман¬ 
да не принадлежит уровню 1, первый из 6 бит указывает но¬ 
мер этого уровня: нулевое значение бита — текущий лексичес¬ 
кий уровень, единичное значение — лексический уровень 1. Ос¬ 
тальные 5 бит содержат порядковый номер операнда данного» 
уровня. (Если этот вопрос представляется читателю недоста¬ 
точно ясным, следует обратиться к упр. 23.1 в конце данной 
главы.) 

Второе изменение архитектуры учебной ПЛ-машины заклю¬ 
чалось в уменьшении длины новой команды SLOAD до 8 бит, 
выполненном по описанной выше схеме, только первые 2 бит 
команды SLOAD приняты равными 01. Результатом двух по¬ 
следних изменений, связанных с усовершенствованием средств: 
адресации, явилось определение 16-битовых команд LNAME 
и LLOAD со следующей структурой формата: первые 5 бит — 
идентификатор типа команды, следующие 3 бит — указатель, 
лексического уровня, последние 8 бит — порядковый номер 
операнда. Благодаря всем четырем изменениям показатель А1 
(общее число битов команд программы) удалось уменьшить В: 
среднем на 23%, а показатель А5 (число битов команд, извле¬ 
каемых из памяти) —на 13,5%. Кроме того, было установлено, 
что в среднем ~92% адресов в программе могут теперь быть- 
представлены в более короткой форме —посредством команд 
SNAME и SLOAD. 
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Далее анализу было подвергнуто представление данных, и 
в частности констант, например константа 1 в операторе 
А=А+1. Были установлены определенные закономерности. Во- 
первых, константы представляются в виде слов в стеке данных 
и адресуются на соответствующем лексическом уровне. По¬ 
скольку константам должны присваиваться порядковые номера, 
возникает необходимость использования длинных форм пред¬ 
ставления адресов лексического уровня. Во-вторых, каждый 
раз, когда требуется константа, ее необходимо извлекать из 
стека данных, а это увеличивает значение показателя А4. И на¬ 
конец, анализ частоты использования констант разных типов 
показал, что 72% всех констант имеют тип FIXED (двоичное 
целое число), причем значение половины констант этого типа 
равно 1, а 99% — менее 64. Следовательно, хранение константы 
как слова в стеке данных ведет к неоправданно большому пе¬ 
рерасходу памяти, т. е. к хранению большого числа ведущих 
нулей, а это увеличивает значение показателя А2. 

Результаты описанного анализа привели к заключению о це¬ 
лесообразности введения в набор команд новой 8-битовой 
команды LITERAL. Ее первые 2 бит, равные 10, указывают, 
что это — команда LITERAL. Следующие 6 бит представляют 
величину, которая интерпретируется как двоичное целое число, 
подлежащее загрузке на вершину стека. В результате лишь 
небольшую часть констант необходимо помещать в стек дан¬ 
ных. Это позволяет уменьшить значения показателей А2, А4 и 
А6. Косвенно уменьшаются также и значения показателей А1 
и А5. Это связано с тем, что уменьшение порядковых номеров 
операндов снижает потребность в «длинных» адресах: добав¬ 
ление команды LITERAL уменьшает диапазон порядковых но¬ 
меров операндов на каждом лексическом уровне в среднем на 
24%- Помимо этого, использование команды LITERAL привело 
к уменьшению размеров таблицы символов и сокращению вре¬ 
мени начальной установки стека данных, выполняемой с по¬ 
мощью команды ENTER. 

Суммарный эффект вышеописанных и некоторых других усо¬ 
вершенствований архитектуры учебной ПЛ-машины оказался 
поистине впечатляющим. В среднем число битов команд стан¬ 
дартной программы (показатель А1) сократилось на 51%, чис¬ 
ло обращений к памяти для извлечения команд (показа¬ 
тель АЗ) —на 37%, и число битов команд, извлекаемых из па¬ 
мяти (показатель А5) —на 58%. Кроме того, число обращений 
к памяти с целью извлечения данных (показатель А4) умень¬ 
шилось на 50%. а число битов данных, извлекаемых из памяти 
{показатель А6)—на 62%. Общий объем средней программы 
сократился на 23%, а число выполняемых команд — на 46%. 
Сравнение реальных программ, написанных для оптимизиро- 
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ванного варианта учебной ПЛ-машины, с аналогичными прог¬ 
раммами на языке ПЛ/1 для Системы 370 показало, что пер¬ 
вые занимают в 13 раз меньший объем памяти и передают че¬ 
рез интерфейс «память-процессор» в 3,5 раза меньше битов ин¬ 
формации [3]. 


ПРИМЕРЫ ОПТИМИЗАЦИИ КОМАНД 
МАШИНЫ SWARD 

В ходе разработки архитектуры SWARD был проведен анализ 
последовательностей команд, аналогичный рассмотренному вы¬ 
ше. В качестве примера ниже приводится анализ взаимодейст¬ 
вия команд проверки условий и передачи управления. 

В первом варианте архитектуры проверка условий и пере¬ 
дача управления выполнялись отдельными, независимыми друг 
от друга командами, как, например, в микропроцессоре 
іАРХ 432. Так, вместо команды EQBF (проверка на равенство; 
переход, если ложно), в набор команд входили трехоперацион¬ 
ные команды проверки отношений (команда EQ —проверка на 
равенство), помещающие логическое значение результата про¬ 
верки отношения в операнд, и отдельно команда BF (переход, 
если «ложно»), проверяющая значение этого операнда на сов¬ 
падение с заданной логической величиной. Однако анализ по¬ 
следовательностей команд показал, что за большинством команд 
проверки отношений следует команда BF, и поэтому операнд 
логического типа, используемый парой таких, следующих одна 
за другой команд, необходим только для установления времен¬ 
ной связи между ними. 

На основании этого было решено исключить указанный опе¬ 
ранд логического типа, создав команды сравнения (например, 
описанные в гл. 15 команды EQBF, LTBF), которые объединя¬ 
ют операции проверки отношений и передачи управления. Бо¬ 
лее того, было предложено не просто добавить эти команды в 
существующий набор команд, а заменить ими команды провер¬ 
ки отношений и BF. Основаниями для такой замены являлись: 
во-первых, стремление свести к минимуму число команд с по¬ 
хожими функциями; во-вторых, предположение, что команды в 
прежнем виде больше не понадобятся; в-третьих, желание со¬ 
кратить количество команд для получения меньшего размера 
кода операции. 

Было установлено, что все возможные варианты проверки 
отношений исчерпываются четырьмя различными конструкция¬ 
ми операторов. Эти операторы показаны в табл. 23.4 совместно 
с кодами команд, генерируемых машиной исходной и модифи¬ 
цированной архитектуры (т. е. после замены команд проверки 
и перехода командами сравнения). 
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Таблица 23.4. Последовательности команд сравнения и перехода 
в машине 


Оператор или фрагмент 
оператора языка програм¬ 
мирования 

Последовательности 
команд исходного 
варианта 

Последовательности 
команд модифици¬ 
рованного варианта 

if в 

BF В, $Х 

EQBF В, 1,$Х 

if X=Y 

EQ В, X, Y 

BF В,$Х 

EQBF X, Y, $Х 

if (X=Y and S=T) 

EQ В, X, Y 

EQ B1.S.T 

AND В,В1 

BF В, $ X 

EQBF X, Y, $Х 
EQBF S,T,$X 

B:=X=Y; 

EQ В, X, Y 

MOVE В,0 

EQBF X, Y, $X 
MOVE В, 1 


Символ €—» обозначает любую операцию отношения 
X, Y, S, Т — целые числа 
В, В1 — логические величины 
I X — адрес перехода 


В табл. 23.5 показаны те же конструкции с указанием их 
оценочной относительной частоты использования, полученной 
на основании анализа статистических данных по применению 
средств языка программирования. Данные, приведенные в таб¬ 
лице, наглядно демонстрируют получаемые при модификации 
преимущества в отношении как времени выполнения, так и 
объема используемой памяти. Согласно табл. 23.4, использова¬ 
ние раздельных команд для проверки отношений и передачи 
управления дает выигрыш в случаях, когда предикат выраже¬ 
ния IF является логической переменной или когда выражение 
в операторе присваивания является отношением. Однако эти 
ситуации, как видно из приведенных статистических данных, 
встречаются довольно редко и не могут быть основанием для 
сохранения раздельных команд проверки отношения и передачи 
управления. 

Приведем другой пример усовершенствования набора команд 
машины SWARD. Ознакомимся с результатами анализа, ана¬ 
логичного описанному выше, которому была подвергнута коман¬ 
да ITERATE. Первоначально у этой команды был еще один 
операнд — приращение (шаг итерации). Анализ показал, что 
почти во всех случаях этот операнд является литералом и era 
величина равна 1. Следующее по частоте использования значе¬ 
ние этого литерала равно —1. (Не случайно в языке Ада в от¬ 
личие от языков ПЛ/1 и ФОРТРАН шаг итерации может быть. 


18-429 
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Таблица 23.5. Сравнение двух вариантов обеспечения командами условной 
■передачи управления 




Исходный вариант J 

Модифицированный 

вариант 

Оператор или фраг¬ 
мент оператора язы¬ 
ка программиро- 

Относительная ча¬ 
стота использова¬ 
ния в программе 

Й| 

§*& 

ііі 

oS3 

§&8-~ 

= c -«§° 
3*°*o 

лёіііа 

O S я в а 

ill 

sag, 

s 2 ° 

Jls 

О « § 

s e г g s 

si«fa 

osSSS 

if В 

10 

28 

40 

44 

56 

if X=Y 

60 

68 

148 

40 

96 

if (X=Y and S= 
=T) 

12 (если X=Y 
«истинно») 

140 

320 

80 

192 


12 (если X=Y 
«ложно») 

140 

320 

80 

96 

S:=X=Y; 

3 (если значение 
результата «истин¬ 
но») 

3 (если значение 
результата «лож¬ 
но») 

40 

108 

104 

184 


40 

108 

104 

140 

Среднее арифметическое 

80 

176 

54 

107 


') Включая команды, теги, данные и результаты. 


равен только 1 или —I 1 ).) В результате оптимизации команды 
ITERATE из расчета на наиболее часто используемое значение 
операнда последний был удален из команды, а шаг итерации 
принят равным 1. Кроме того, в набор команд машины была 
добавлена новая команда ITERATE-REVERSE с фиксирован¬ 
ным значением шага итерации, равным —1. Прежний вариант 
команды ITERATE можно было бы оставить, но его исключи¬ 
ли, руководствуясь тремя доводами, приведенными выше. 

ОПТИМИЗАЦИЯ КОДА ОПЕРАЦИИ 

Хотя это может показаться и не очевидным, изложенные в пре¬ 
дыдущем разделе методы совершенствования некоторых пара¬ 
метров вычислительной системы базируются на явным образом 
не сформулированном принципе устранения избыточности ин¬ 
формации, хранимой в памяти машины. Для формального опре- 


1 > Это справедливо и для языка Паскаль. — Прим, перев. 


ОПТИМИЗАЦИЯ АРХИТЕКТУРЫ ВЫЧИСЛИТЕЛЬНОЙ СИСТЕМЫ 267” 


деления и оценки таких понятий, как избыточность и информа¬ 
ционная емкость, а также для разработки средств минимизации 
избыточности может быть привлечен аппарат теории информа¬ 
ции [4]. 

Одним из достоинств этого аппарата является возможность- 
теоретической оценки действительной информационной емкости, 
сообщения. Эту оценку, обозначаемую буквой Н, часто называ¬ 
ют количеством переданной информации источником, энтропией 
источника или мерой неопределенности сообщений источника 
информации. В качестве отдельных частей сообщения можно- 
рассматривать всю объектную программу, последовательность 
машинных команд, данные программы, адреса машинных команд 
и коды операций. Саму память, или точнее тракт процессор- 
память, можно считать каналом связи. Если части какого-то- 
интересующего нас сообщения рассматривать как независимые 
друг от друга (выше было показано, что это неверно для по¬ 
следовательностей машинных команд или кодов операций, но- 
предположим, мы хотим ограничиться только оптимизацией ко¬ 
дирования отдельных частей команды), то значение Н можег 
быть определено как 

Н= —2 (Р 4 logPj), 


где Рі — вероятность появления і-го символа сообщения. По¬ 
скольку информация представляется в битах, логарифмы берут¬ 
ся по основанию 2. Избыточность кодирования символов сооб¬ 
щения может быть определена следующим образом: 


Действительный средний размер символа * 

Диапазон возможных значений избыточности простирается от О 
(избыточность отсутствует) до 100% (бесконечная избыточ¬ 
ность) . 

Если эта оценка применяется для оптимизации представле¬ 
ния кода операции, то Рі обозначает вероятность появления 
і-го кода операции, а суммирование проводится по набору от¬ 
дельных кодов операции. Величина Н — это среднее число би¬ 
тов информации в коде операции. Вероятность появления того 
или иного кода операции может быть либо статической (если 
объектом оптимизации является память, занимаемая кодами 
операции), либо динамической (если оптимизируется передача 
по тракту процессор-память). Однако, как уже отмечалось, су¬ 
ществует сильная корреляция между статической и динамичес¬ 
кой частотами появления кодов операции, что позволяет произ¬ 
вольно выбирать в качестве предмета оптимизации одну из них 
и получать близкие к оптимальным результаты для другой. 
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Рассмотрим простой пример. Пусть машина имеет семь ко¬ 
манд с именами А, В, С, D, Е, F и G. Предположим, что для 
рассматриваемой машины длина кода операции фиксированна, 
тогда ее оптимальное значение равно 3 бит, а суммарная длина 
кодов операции программы из 1000 команд составит 3000 бит. 
Допустим, что вероятность появления семи подобных команд 
соответствует содержимому табл. 23.6. (Данные, приведенные в 
таблице, не должны вызывать удив¬ 
ления: мы уже видели, что частоты 
появления различных команд могут 
существенно отличаться друг от 
друга.) 

Величина Н для этой группы ко¬ 
манд в предположении взаимной не¬ 
зависимости появления команд, т. е. 
без учета частоты появления опреде¬ 
ленных последовательностей команд, 
равна 1,88. Это означает, что, хотя 
длина поля представления кода опе¬ 
рации составляет 3 бит, число битов 
информации в каждом таком поле в 
•среднем равно 1,88. Избыточность в этом случае составляет 1— 
1,88/3, т. е. 37%. Очевидно, что должно существовать более эф¬ 
фективное представление кодов операции. 

Повышение эффективности кодирования можно достичь, ис¬ 
пользуя коды переменной длины, обратно пропорциональной 
частоте появления данной операции. Наиболее часто встречаю¬ 
щиеся команды должны иметь самый короткий код операции, а 
редко выполняемые — самый длинный. Вместо того чтобы в 
каждом случае формулировать свой принцип формирования ко¬ 
дов операций, можно воспользоваться так называемым алгорит¬ 
мом Хафмена, который обеспечивает оптимальное представле¬ 
ние кода операции [4]. Действительно, одна из фундаменталь¬ 
ных теорем теории информации доказывает, что при использо¬ 
вании кода Хафмена средний размер поля кода операции для 
рассмотренного случая принадлежит диапазону 1,88—2,21 бит. 
(Величина 2,21 является результатом вычисления выражения 
1,88+1/3, где 3 — размер поля представления кодов данной 
группы операций в том случае, когда длина поля фиксирован¬ 
на.) Кодирование, согласно алгоритму Хафмена, дает наилуч¬ 
шие практически возможные результаты, однако обычно не поз¬ 
воляет достичь желаемого предела, оцениваемого величиной Н, 
поскольку в этом случае коды операции должны быть представ¬ 
лены долями бита. 

Кодирование, согласно алгоритму Хафмена, производится 
следующим образом. Строится двоичное дерево так, чтобы 


Таблица 23.6. Вероятность 
появления команд 


Команда 

Вероятность 
появления, Р 

А 

0,50 

В 

0,30 

С 

0,10 

D 

0,03 

Е 

0,03 

F 

0,02 

-G 

0,02 
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подлежащая кодированию информация — коды операций — со¬ 
держалась в концевых узлах графа. Первоначально в каждом 
узле указывается соответствующая ему частота использования 
кода операции данного типа. Эти узлы считаются «непокрыты¬ 
ми». Затем с целью получения одного непокрытого узла со зна¬ 
чением частоты, равным 1,0, выполняется итеративная процеду¬ 
ра «покрытия» узлов. Она состоит в следующем: отыскиваются 
два «непокрытых» узла с наименьшими значениями частот и 
«покрываются» путем их сведения в единый узел со значением 
частоты, равным сумме зна¬ 
чений частот узлов, соеди¬ 
няемых звеньями с данным, 
только что сформирован¬ 
ным и «непокрытым» узлом. 

Пример такого построения 
иллюстрирует рис. 23.1. Чис¬ 
ло звеньев от узла с часто¬ 
той 1,0 до оконечного узла 
представляет собой опти¬ 
мальный размер кода опе¬ 
рации, представляемого 
этим узлом. Помечая нулем 
и единицей соответственно 
левое и правое звенья, вхо¬ 
дящие в тот или иной узел, 
можно сформировать двоич¬ 
ное представление кода опе¬ 
рации данного типа. 

Полученные данным ме¬ 
тодом коды операций для упомянутых выше команд А, В, С, 
D, Е, F и G приведены в табл. 23.7. Заметим, что чаще других 
используемая команда А имеет 1-битовый код операции, а ре¬ 
же других выполняемые команды D — G — 5-битовый код. Сред¬ 
няя длина кода операции получается как сумма произведений 
частоты использования каждой команды на длину ее кода опе¬ 
рации. В данном случае средняя длина оказывается равной 
1,90 бит, избыточность составляет 1%, а число битов кодов 
операций в программе из 1000 команд равно теперь не 3000, 
а 1900. 

Следует обратить внимание на однозначность дешифриро¬ 
вания кодов операций, т. е. на возможность для процессора 
безошибочного определения типа команды. Если бы код опера¬ 
ции для В, например, был изменен с 01 на 10, то указанная од¬ 
нозначность оказалась бы утерянной, т. е. процессор был бы 
не способен различить команды А и В. 

Несмотря на то что кодирование, согласно алгоритму Хаф- 



Рис. 23.1. Дерево кодирования 
операций по методу Хафмена. 
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Таблица 23.7. Кодирование операций по методу 
Хафмена 


Команда 

Вероятность і 
появления, Р,- 

Код опера- 

операции, 

бит 

А 

0,50 


! 

В 

0.30 

01 

2 

С 

0,10 

001 

3 

D 

0,03 

00000 

5 

Е 

0,03 

00001 

5 

F 

0,02 

00010 

5 

G 

0,02 

00011 

5 


мена, обеспечивает оптимальное представление кодов операций,, 
эта процедура никогда не использовалась. Основным препятст¬ 
вием на пути практической реализации такого решения являет¬ 
ся необходимость адресации к памяти машины с точностью до 
1 бит. (Такой возможностью располагают вычислительные сис¬ 
темы 432 фирмы Intel и 1700 фирмы Burroughs.) Другим за¬ 
труднением на пути подобного решения является то, что прин¬ 
ципиально каждый код операции может иметь свою длину, от¬ 
личную от длины других кодов операций, что усложняет про¬ 
цесс декодирования этих кодов в процессоре. Однако в настоя¬ 
щее время с появлением программируемых логических схем, 
матричного типа декодирование значительно упростилось. 

Если кодирование по методу Хафмена оказывается трудоем¬ 
ким или в нем нет необходимости, можно принять компромисс¬ 
ное решение. Надо выбрать две или более фиксированные дли¬ 
ны поля кода, и использовать самые короткие коды в наиболее- 
часто выполняемых командах. Как будет показано на несколь¬ 
ких примерах, такое решение дает значительную экономию па¬ 
мяти по сравнению с использованием кодов операций постоян¬ 
ной длины. 

Представим себе, что в некоторой гипотетической архитек¬ 
туре коды операций могут иметь длину 2 или 4 бит. В табл. 23.8 
показаны значения кодов операций. И в данном случае коды 
составлены таким образом, чтобы обеспечить однозначное деко¬ 
дирование команд. Средняя длина кода операции равна 
2,20 бит, избыточность составляет 15%, а общее количество би¬ 
тов кодов операций в программе из 1000 команд оказывается 
равным 2200 вместо 3000. 

Другим преимуществом такого метода кодирования, не от¬ 
меченным выше, является то, что он не накладывает ограниче¬ 
ний на максимально допустимое число различных кодов опера¬ 
ций. Указанные в табл. 23.8 нулевые значения первых двух би¬ 
тов кода операции называют кодом переключения (escape со- 
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Таблица 23.8. Компромиссный вариант кодирования 
операций 


Команда 

Вероятность 
появления, Pj 

Код опера- 

^операции, 

А 

0,Е0 

11 

2 

В 

0,30 

10 

2 

С 

0,10 

01 

2 

D 

0,03 

ООП 

4 

Е 

0,03 

0010 

4 

F 

0,02 

0001 

4 

G 

0,02 

0000 

4 


<іе). Последний используется для указания того, что код опера¬ 
ции имеет длину больше чем 2 бит. Используя этот же саособ 
Л л я индикации изменения длины кода операции применительно 
к следующей паре его битов, можно получить коды операций 
любой длины. Однако в таком случае комбинацию битов 00...00 
нельзя использовать для обозначения кода операции. Следова¬ 
тельно, в табл. 23.8 команда G должна была бы иметь 6-бито¬ 
вый код операции 000011. Это увеличивает средний размер ко¬ 
да операции до 2,24 бит, что является незначительной платой 
за достигаемую при этом гибкость кодирования. Однако во мно¬ 
гих случаях увеличения среднего размера кода операции не 
произойдет, поскольку число команд редко оказывается равным 
количеству всех возможных значений кода операции. 

ОПТИМИЗАЦИЯ КОДА ОПЕРАЦИИ 
В ЭВМ В1700 

В гл. 12 была описана оптимизация такого типа при рассмотре¬ 
нии архитектуры ЭВМ В1700, ориентированной на язык 
КОБОЛ. Коды операций имеют длину 3 или 9 бит. Семь наи¬ 
более часто используемых команд имеют 3-битовые коды опера¬ 
ции, восьмое значение такого кода (из числа возможных для 
3-битового кода) означает, что следующие 6 бит также являют¬ 
ся частью кода операции. Теперь мы рассмотрим оптимизацию 
другой архитектуры ЭВМ В1700 — архитектуры, ориентирован¬ 
ной на языке SDL [5]. 

Операционная система и компилятор ЭВМ В1700, написан¬ 
ные на языке SDL, выполняются этой машиной при условии, 
что ее архитектура ориентирована на этот язык. При разработ¬ 
ке архитектуры проектировщики сопоставляли достоинства раз¬ 
личных способов кодирования операции и выбрали для кодов 
три длины: 4,6 и 10 бит. Из 16 возможных комбинаций значе¬ 
ний первых четырех битов команды десять обозначают наибо- 
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Таблица 23.9. Сравнение разных вариантов кодирования операций в ЭВМ 
В1700 с архитектурой, ориентированной на язык SDL 


Метод кодирования 

Количество би¬ 
операций команд 

системы 

Выигрыш, % 

Затраты време¬ 
ни на декодиро¬ 
вание команд, % 

Метод с использованием длины 
поля 8 бит 

301 248 

0 

0 

Метод 4—6—10 

184 966 

39 

2,6 

Метод Хафмена 

172 346 

43 

17,2 


лее часто используемые команды, пять являются указанием на 
то, что код операции имеет длину 6 бит, и один указывает, что 
длина кода операции равна 10 бит. 

Для оценки целесообразности такого выбора было проведе* 
но сравнение с кодированием операций 8-битовым кодом фик¬ 
сированной длины и с кодированием согласно алгоритму Хаф- 
мена. В табл. 23.9 приведены сравнительные данные для этих 
трех способов кодирования в виде суммарного числа битов ко¬ 
дов операций, содержащихся в программах операционной систе¬ 
мы, и относительных затрат времени на декодирование команд. 
Как следует из таблицы, выбранное решение оказалось вполне 
разумным: оно дает результаты, близкие к методу Хафмена по 
эффективности, и в то же время дополнительные затраты вре¬ 
мени на декодирование команд незначительны. Набор кодов 
операций разной фиксированной длины (4,6 и 10) уменьшает на 
39% число битов, отводимых в операционной системе на коды 
операций. Это является существенным достоинством выбранно¬ 
го решения, поскольку в архитектуре, ориентированной на язык 
SDL, коды операции занимают почти треть общего объема 
программы. 


ОПТИМИЗАЦИЯ КОДА ОПЕРАЦИИ 
в МАШИНЕ SWARD 

В гл. 15 при определении набора команд машины SWARD 
указано, что код операции каждой команды формируется как 
совокупность того или иного количества 4-битовых групп. Дово¬ 
ды в пользу подобного кодирования операций с учетом частоты 
использования различных команд приводятся ниже. 

Поскольку кодирование операций машины SWARD осуще¬ 
ствлялось на той стадии проектирования, когда существовал 
только проект машины на бумаге, естественно возникновение 
вопроса, что использовалось в качестве источника информации 
о частоте употребления тех или иных команд. Эта информация 
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Таблица 23.10. Различные варианты кодирования операций в машине 
SWARD 


Команда 1 ) 

Вероятность 
появления, Pj 

Показатель ^ 
ранжирова- 

Размер кода 

операции, бит 

Метод Хаф- 

< 

1 

S 

1 

1 

S 

MOVE 

24 

1 

2 

4 

4 

* 

4 

ADD 

14 

2 

3 

4 

4 

4 

BRANCH 

11 

3 

3 

4 

4 

4 

EQBF 

7 

4 

4 

4 

4 

4 

SUBTRACT 

5 

5 

4 

4 

4 

4 

NEBF 

4 

6 

5 

4 

4 

4 

LTBF 

3 

7 

5 

4 

4 

4 

GTBF 

3 

8 

5 

8 

4 

4 

CALL 

2,5 

9 

5 

8 

4 

4 

MULTIPLY 

2 

10 

6 

8 

4 

4 

ITERATE 

2 

11 

6 

8 

4 

4 

LEBF 

2 

12 

6 

8 

4 

4 

GEBF 

2 

13 

6 

8 

4 

4 

ACTIVATE 

1,5 

14 

6 

8 

4 

4 

DIVIDE 

1,5 

15 

6 

8 

8 

8 

MOVESS 

1,5 

16 

6 

8 

8 

8 

CONVERT 

1,5 

17 

6 

8 

8 

8 

RETURN 

1,5 

18 

6 

8 

8 

8 

COMPLEMENT 

1.5 

19 

6 

8 

8 

8 

RANGECHECK 

1,5 

20 

6 

8 

8 

8 

AND 

0,5 

21 

7 

8 

8 

8 

OR 

0,5 

22 

7 

8 

8 

8 

INDEX 

0,5 

23 

7 

8 

8 

8 

ITERATEREV 

0,4 

24 

8 

8 

8 

8 

SEND 

0,4 

25 

8 

8 

8 

8 

RECEIVE 

0,4 

26 

8 

8 

8 

8 

ABSOLUTE 

0,3 

27 

8 

8 

8 

8 

LENGTH 

0,3 

28 

8 

8 

8 

8 

CONCAT 

0,2 

29 

10 

8 

8 

8 

Следующие 15 команд 

1,5 

30-44 

10 

8 

12 

16 

Следующие 15 команд 

1,5 

45-59 

10 

8 

16 

16 

Все остальные команды 

0,5 

60-64 

10 

8 

20 

16 


У К° ман Да MARKER с 4-битовым кодом о_ г ___ 

) Метод А —для первых восьми команд размер к 
следующих 128 команд-8 бит. Р Р 

щих 1 5 М ко Т м?нд Г8 Д бит П и Р т“д ‘ 5 К0Манд размер кода опе Р аааи Р»»ен 4 бит, для следую- 
щих Мб'комаіщ — 1б Я бит РВЬ1Х 15 команд Р азме Р кода операции равен 4 бит. для следую- 


получена «методом языковых фрагментов» [3], а именно путем 
анализа различных статистических данных і[1, 3, 6, 10 и т.п.] 
о частоте использования операторов языка программирования. 
На основании этого анализа и сопоставления возможностей ма¬ 
шины SWARD делалось заключение о том, какие машинные 
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команды порождаются теми или иными операторами языка 
программирования и какова частота генерирования таких 
команд. 

Команды машины SWARD и полученные указанным обра¬ 
зом оценки частоты их использования (вероятности появления) 
приведены в табл. 23.10. Значения частот несколько изменены 
для того, чтобы учесть команды, не имеющие непосредственных 
эквивалентов в конструкции того или иного оператора языка 
программирования высокого уровня. Неточность в оценке частот 
находится в пределах допустимых значений, поскольку для оп¬ 
тимизации имеет значение только относительная расстановка 
(ранжирование) команд по частоте их применения. Фактически, 
как будет показано ниже, небольшая неточность в ранжирова¬ 
нии команд либо не влияет, либо оказывает лишь незначитель¬ 
ное влияние на конечный результат. 

Команда MARKER, хотя и имеет короткий 4-битовый код 
операции, исключена из рассмотрения, поскольку частоту ее ис¬ 
пользования определить затруднительно. 

Прежде всего на основании имеющихся данных о частотах 
была рассчитана величина Н. Ее значение оказалось равным 
3,9 бит. Расчеты выполнены в предположении независимости 
использования команд, поскольку чем выше уровень языка 
программирования, тем меньше зависимость использования 
данной команды от предыдущих команд, образующих ту или 
иную последовательность команд в программе. Таким образом, 
для кода операции фиксированной длины (8 бит, или 2 токен) 
потребовалось бы поле представления, более чем в два раза 
превышающее теоретически необходимое. 

Хотя была принята схема кодирования с использованием 
4-битовых составных элементов кода операции (такую длину 
имеет минимальная адресуемая часть памяти), было проведено 
также кодирование методом Хафмена для выявления лучшего 
возможного представления кода операции. Размеры кодов опе¬ 
раций, полученных по методу Хафмена, приведены в табл. 23.10. 
Средняя длина кода операции оказалась равной 4,1 бит. Были 
рассмотрены также три метода кодирования: метод А —8/128, 
Б—15/15/... и В—15/15/256. Согласно методу А, длина кода опе¬ 
рации восьми наиболее часто используемых команд равна 4 бит 
(1 токен), а следующих 128 команд —8 бит (2 токен). Метод 
может быть реализован следующим образом. Если первый бит 
первого токена равен 1, код операции состоит из 1 токен 
(1ХХХ). Код операции всех остальных команд имеет вид 

оххххххх. 

В соответствии с методом Б длина кода операции 15 наибо¬ 
лее часто используемых команд равна 1 токен, следующих 
15 команд —2 токен и т. д. Если первый токен не заполнен 
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только нулями, то длина кода операции равна 1 токен. Если 
же все биты первого токена равны нулю, а у второго токена 
имеются отличные от нуля биты, то длина кода операции равна 
2 токен, и т. д. 

Согласно методу В, коды операций длиной 4 и 8 бит фор¬ 
мируются аналогичным образом; длина всех других кодов опе¬ 
раций полагается равной 16 бит. 

За исключением того факта, что кодирование по методу 
Хафмена всегда дает оптимальные результаты, в настоящее 
время отсутствует какой-либо общепринятый способ сопоставле¬ 
ния других методов кодирования с целью выбора наилучшего, 
помимо их экспериментальной проверки. В табл. 23.10 приведе¬ 
ны данные о длине кодов операций, формируемой согласно трем 
перечисленным методам. Умножая длину каждого кода на со¬ 
ответствующую частоту использования команды и складывая 
полученные произведения, имеем среднюю длину кода опера¬ 
ции: 5,2 бит для метода А, 4,85 бит для метода Б и 4,89 бит 
для метода В. Окончательный выбор был сделан в пользу по¬ 
следнего метода, по эффективности незначительно уступающе¬ 
го второму, но более простому по реализации. 


ОПТИМИЗАЦИЯ ПРЕДСТАВЛЕНИЯ 
АДРЕСОВ 

Как уже упоминалось, процедура, аналогичная рассмотренной, 
может быть проведена и для других видов информации, таких, 
как данные или адреса данных и команд. Ниже рассматривает¬ 
ся уменьшение избыточности информации, используемой для 
представления адреса. 

Дополнительно к работам по оптимизации представления 
кода операции в ЭВМ В1700 фирмы Burroughs с архитектурой, 
ориентированной на язык SDL, была проведена оптимизация 
кодирования адресов данных [5]. Архитектура ЭВМ В1700 
предусматривает адресацию лексического уровня. 

Разработчики приняли решение обеспечить возможность ис¬ 
пользование до 16 лексических уровней и 1024 переменных на 
каждом уровне, что предполагает манипулирование на том или 
ином лексическом уровне 14-битовыми адресами — 4 бит для 
номера лексического уровня и 10 бит для порядкового номера 
или индекса переменной на этом уровне. После написания на 
языке SDL программ операционной системы и компиляторов 
■был выполнен анализ частоты использования реальных адресов. 
Как можно было предположить, неравномерность оказалась 
значительной, что явилось следствием высокой степени избыточ¬ 
ности представления адресов фиксированным числом битов. 
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Результаты описываемых исследований привели к измене¬ 
нию архитектуры машины —к отказу от применения адресов 
фиксированной длины и переходу к адресам, длина которых оп¬ 
ределяется частотой их использования. Адреса могут иметь дли¬ 
ну 8, 11, 13 или 16 бит. Формат адреса состоит из трех полей: 
префикса, номера лексического уровня и порядкового номера 
адресата, принадлежащего этому уровню. Двухбитовое поле 
префикса определяет размер адреса. Длина поля номера лек¬ 
сического уровня может составлять 1—4 бит, длина поля поряд¬ 
кового номера — 5 или 10 бит. Анализ адресов данных в коман¬ 
дах операционной системы показал, что если в первоначальной 
версии 9174 адреса занимали 128436 бит, то в новой версии ис¬ 
пользуется 94 900 бит, т. е. объем необходимой памяти сокра¬ 
тился на 26%. 

Оптимизация адресов команд осуществлялась аналогичным 
образом. Такой адрес состоит из номера сегмента программы и 
смещения команды внутри сегмента (в битах). Разработчики 
предусмотрели возможность использования до 1024 сегментов 
по 1 млн. бит в каждом, что приводит к применению 30-битовых 
адресов команд: 10 бит для имени сегмента и 20 бит для сме¬ 
щения команды внутри сегмента. Однако уже в первоначальном 
проекте машины была предусмотрена возможность использова¬ 
ния 5- или 10-битовых имен сегментов и 12-, 16- или 20-бито¬ 
вых смещений. Как только выяснилось, что многие обращения 
к командам локализованы внутри сегмента, в архитектуру ма¬ 
шины были внесены изменения, допускающие использование 
нулевого (длиной 0 бит) имени сегмента. Поскольку многие об¬ 
ращения производятся к началу других сегментов, было разре¬ 
шено задание нулевого смещения. Таким образом, формат ад¬ 
реса команды состоит из трех полей, в которых располагаются: 
3-битовый префикс, определяющий представление адреса; имя 
сегмента длиной 0, 5 или 10 бит и смещение длиной 0, 12, 16 
или 20 бит (допускаются только восемь из всех возможных со¬ 
четаний форматов полей представления имен сегментов и сме¬ 
щений). 

Чтобы оценить целесообразность использования этой интуи¬ 
тивно выбранной версии оптимизации, были собраны статисти¬ 
ческие данные о частоте использования различных адресов в 
программах, прошедших стадию компилирования. Оказалось, 
что предложенная версия достаточно близка к оптимальному 
решению и не требует изменений. Анализ 3767 адресов команд 
операционной системы показал, что они занимают 74 303 бит 
вместо 120 544 бит, которые потребовались бы для машины с 
байтовой структурой адресного пространства и фиксированной 
длиной адресов при том же диапазоне изменения адресов. Ре¬ 
зультирующая экономия памяти составила 38% • 
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ОПТИМИЗАЦИЯ ПРЕДСТАВЛЕНИЯ АДРЕСОВ 
В МАШИНЕ SWARD 

Архитектура машины SWARD может служить другим примером 
уменьшения избыточности в представлении адресов, однако спо¬ 
соб, благодаря которому это достигнуто, отличен от способа, 
примененного разработчиками ЭВМ В1700. Оптимизация пред¬ 
ставления адресов возможна, если учесть следующие особенно¬ 
сти данной архитектуры: во-первых, каждый модуль имеет свое 
собственное адресное пространство; во-вторых, адресное про¬ 
странство данных отличается от адресного пространства ко¬ 
манд; в-третьих, модуль сам определяет размеры адресов дан¬ 
ных и команд, относящихся к нему. 

Несмотря на то что первоначально только третья из указан¬ 
ных особенностей послужила основой для оптимизации пред¬ 
ставления адресов, на сокращение объема памяти, занимаемой 
адресами, влияют все указанные особенности. Рассмотрим ма¬ 
шину, в которой все программы размещаются в едином обшир¬ 
ном адресном пространстве или в нем по крайней мере одна 
любая программа помещается полностью, как в большинстве 
традиционных машин. Это означает, что посредством каждого 
адреса можно сослаться на любую ячейку памяти, однако, по¬ 
скольку, например, семантика языков программирования накла¬ 
дывает ряд ограничений, существует сильная взаимосвязь меж¬ 
ду командами и адресами. Так, машинные команды, соответст¬ 
вующие подпрограмме на языке высокого уровня, ссылаются 
только на небольшую часть всех ячеек памяти, доступных для 
адресации. Следовательно, коды адресов содержат значитель¬ 
ную избыточность. В машине SWARD значительная часть этой 
избыточности устранена. Поскольку каждый модуль располага¬ 
ет своим собственным адресным пространством, можно ограни¬ 
читься меньшей длиной адреса данных. 

Аналогичным образом, машине, размещающей команды и 
данные в одном адресном пространстве, присуща неоправдан¬ 
ная избыточность в представлении адресов. Например, не все 
ячейки памяти с равной вероятностью оказываются адресуемы¬ 
ми командами передачи управления; вероятность указания в 
таких командах адресов ячеек памяти, содержащих данные, 
равна 0. Точно так же не все ячейки памяти равновероятно ад¬ 
ресуемы командой ADD (СЛОЖЕНИЕ). В частности, в этой 
команде никогда не указываются адреса ячеек, содержащих 
команды. Таким образом, размещение команд и данных в раз¬ 
личных адресных пространствах уменьшает избыточность и 
приводит к сокращению размера поля, необходимого для пред¬ 
ставления адресов. 

Внимательный читатель может обнаружить еще два источ¬ 
ника избыточности. Первый из них обусловлен тем обстоятель- 
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ством, что обращение к разным переменным в программе про¬ 
исходит с различной частотой. Следовательно, значения адресов 
не равновероятны и вычисление величины Н показывает, что 
.при фиксированной длине адресов имеет место избыточность. 
Второй и более существенный источник избыточности в пред¬ 
ставлении адресов обусловлен тем, что некоторые значения ад¬ 
ресов никогда не используются, так как не указывают на нача¬ 
ло полей представления данных ячеек памяти с данными. В ка¬ 
честве примера рассмотрим применительно к машине SWARD 
модуль с четырьмя ячейками. Длина первой ячейки составляет 
4 токен; второй — 6 токен, третьей — 9 токен и последней — 
4 токен. Тогда нумеруемые по порядку адреса ячеек могут 
иметь только следующие значения: 1, 5, 11 и 20. Однако приня¬ 
тая форма представления адресов позволяет задавать и другие 
-значения последних: 2, 3, 4, 6 и т. д., что и объясняет появле¬ 
ние значительной избыточности. 

Такой тип избыточности анализировался в процессе разра¬ 
ботки архитектуры SWARD. Были рассмотрены два способа 
адресации: прямая и косвенная. Избыточность при прямой ад¬ 
ресации очевидна: поле адреса содержит смещение ячейки внут¬ 
ри адресного пространства модуля. При косвенной адресации 
в качестве адреса используется порядковый номер ячейки; со¬ 
ответствующий модуль содержит таблицу, называемую табли¬ 
цей смещения ячеек, в которой для каждой ячейки указывается 
•ее смещение внутри адресного пространства. 

Поскольку ответ на вопрос, какой из способов предпочти¬ 
тельнее, не является очевидным, проводится сравнение указан¬ 
ных способов по следующим характеристикам: физическому 
размеру модуля; объему информации, передаваемому из памя¬ 
ти в процессор при выполнении модуля; количеству операций, 
выполняемых процессором для преобразования поля адреса в 
адрес физической ячейки; компактности размещения адресных 
ссылок (например, если процессор должен извлечь 2 токен дан¬ 
ных, желательно, чтобы они размещались в смежных ячейках). 
При этом используются следующие обозначения: 

А — количество адресных полей в модуле (адресные поля 
размещаются в командах и ячейках «косвенный доступ к дан¬ 
ным») ; 

F — количество ссылок на операнды во время выполнения 
модуля; 

С — количество ячеек в модуле; 

S — размер (в токенах) адресного пространства модуля. 

Функция CEIL используется для увеличения числа до бли¬ 
жайшего большего целого [CEIL (2) =2, CEIL (2,1) =3]. Все ло¬ 
гарифмы берутся по основанию 16. 
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Что касается размера модуля, то для обоих способов адре¬ 
сации он одинаков, если не учитывать пространство памяти,, 
занимаемое адресами и таблицей смещения ячеек. Постоянна» 
для обоих способов величина в дальнейшем во внимание при¬ 
ниматься не будет. При косвенной адресации выражение 
A xCEIL (log С)-I-С х CEIL (log S) ] 

определяет размер пространства, занимаемого адресными поля¬ 
ми и таблицей смещения ячеек. При прямой адресации подоб- 
ная величина определяется согласно выражению 
AxCEIL (logS). 

Отношение этих двух выражений имеет следующий вид: 
CEIL (log С) , С 
CEIL (log S) "f" А • 

Если значение полученного выражения меньше 1, то пред¬ 
почтительнее косвенная адресация. 

Поскольку только одно соотношение (S>C) всегда истин¬ 
но, ни один из методов не может быть выбран в качестве уни¬ 
версального для всех случаев. Но так как обычно S намного» 
больше С (примерно на порядок), первое слагаемое приведен¬ 
ного выше выражения имеет, как правило, следующие значения: 
1,0; 0,67 или 0,5. Если предположить, что для всех модулей- 
значения С оказываются равномерно распределенными в диапа¬ 
зоне 2—300 и S = 10-С, то ожидаемым значением первого сла¬ 
гаемого будет 0,72. Очевидно выполнение соотношения А>С,_ 
так как в противном случае модуль будет содержать перемен¬ 
ные, к которым не производится обращения. Если типовой мо¬ 
дуль в среднем содержит не более трех обращений к каждой' 
ячейке, то значение приведенного выше выражения окажете» 
больше 1. Отсюда следует, что однозначный выбор способа ад¬ 
ресации невозможен. Какой способ окажется более эффектив¬ 
ным, имея в виду экономию памяти машины, зависит от харак¬ 
теристик конкретной программы. 

При рассмотрении передачи данных из памяти в процессор¬ 
оба способа оцениваются одинаковой для них составляющей, 
которая в дальнейшем при сопоставлении этих способов может 
быть исключена из рассмотрения (речь идет о пересылке кодов, 
операции литералов и содержимого ячеек). Поэтому сравни¬ 
тельный анализ сводится к оценке объема передаваемой адрес¬ 
ной информации. При косвенной адресации эта величина опре¬ 
деляется выражением 

F xCEIL (log С) + F xCEIL (logS), 

которое включает информацию о номере ячейки и ее смещении; 
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при каждой адресации к ячейке. При использовании прямой 
адресации объем информации равен 

FxCEIL(logS). 

Последнее выражение демонстрирует явное преимущество пря¬ 
мой адресации. 

Что касается затрат на вычисление адреса 1 , то при косвен¬ 
ном способе адресации требуется большее число операций про¬ 
цессора, поскольку номер ячейки должен быть уменьшен на 
размер элемента в таблице смещения ячеек для получения ве¬ 
личины смещения. Таким образом, в данном случае использова¬ 
ние прямой адресации также оказывается более желательным. 

Сравнение затрат на передачу данных трудно выполнить с 
большой точностью, поскольку использование способа адреса¬ 
ции, связанного с большим объемом передаваемых данных, мо¬ 
жет сопровождаться выполнением только небольшого числа 
операций извлечения данных из памяти, если они расположены 
в смежных ее областях; в то же время при использовании дру¬ 
гого способа, возможно, меньшие по объему данные окажутся 
размещенными в разных, несмежных друг с другом участках 
памяти и для их извлечения потребуется больше операций. 
Следовательно, необходима оценка степени локальности адрес¬ 
ных ссылок. Однако для способа косвенной адресации в этом 
нет необходимости, поскольку при использовании косвенной 
адресации требуется передача дополнительных данных, разме¬ 
щаемых отдельно от основной информации, так, элемент табли¬ 
цы смещения ячеек расположен отдельно от поля адреса. 

На основании проведенного анализа было отдано предпоч¬ 
тение способу прямой адресации (адресации посредством дан¬ 
ных о смещении ячейки) перед способом косвенной адресации 
(адресации посредством данных о номере ячейки). 


ОПТИМИЗАЦИЯ АРХИТЕКТУРЫ 
МИКРОПРОЦЕССОРА ІАРХ 432 

Архитектура микропроцессора іАРХ 432 является примером вы¬ 
сокой степени оптимизации архитектуры вычислительной систе¬ 
мы по многим параметрам. 

Хорошо известно, что значительная часть данных, исполь¬ 
зуемых в программах, является константами, причем по мере 
уменьшения значения константы вероятность ее использования 
резко возрастает; наиболее часто используемыми являются зна¬ 
чения 0 и 1. Отказавшись от включения числовых литералов 
малой величины в команды вместо адресов операндов (как это 
сделано в машине SWARD), разработчики процессора іАРХ 432 
сосредоточили основное внимание на оптимизации манипулиро- 
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вания константами 0 и 1. Последние включены в набор команд, 
т. е. определяются специальными командами, использующими 
эти величины как неявные операнды. Это объясняет происхож¬ 
дение таких команд, как ZERO-ORDINAL, ONE-SHORT-ORDI¬ 
NAL, INCREMENT-INTEGER и EQUAL-ZERO-CHARACTER. 

В поле класса длиной 4 или 6 бит указывается количество и 
длина операндов команды. Для наиболее употребимых команд 
(например, с двумя 16-битовыми или тремя 32-битовыми опе¬ 
рандами) используется 4-битовое поле класса (см. табл. 18.1). 

В поле формата указываются порядок и местоположение 
операндов — стек или какое-либо другое место. Если операндов 
нет, то это поле отсутствует; при наличии одного операнда оно 
содержит единственный бит и т. д. 

Во многих случаях представление кода операции определя¬ 
ется частотой использования соответствующей команды. Так, 
команда DIVIDE-SHORT-ORDINAL, используемая намного ре¬ 
же, чем команда DIVIDE-INTEGER, имеет 5-битовый код опера¬ 
ции, а вторая из названных команд — 4-битовый код. Некоторые 
команды, например BRANCH, полностью определяются содер¬ 
жимым поля класса и поэтому не имеют поля кода операции. 

Адреса также кодируются в соответствии с частотой их ис¬ 
пользования, хотя, возможно, более эффективно было бы ор¬ 
ганизовать ссылки к локальным переменным контекста. Для 
выбора первых 16 сегментов в каждом из четырех входных 
списков доступа используется короткий 6-битовый селектор сег¬ 
мента объекта. В редких случаях, когда этого оказывается не¬ 
достаточно, можно использовать длинный 16-битовый селектор. 
Аналогично смещение может занимать 7 или 16 бит. Учитывая, 
что большинство переходов осуществляется к близлежащим 
«точкам» — командам, — адрес перехода может представлять 
собой 10-битовую относительную величину или 16-битовое аб¬ 
солютное смещение в сегменте команд. 

В литературе, список которой приводится ниже [7—13], со¬ 
держатся примеры разных вариантов кодирования команд и ад¬ 
ресов, используемых вычислительными системами различной ар¬ 
хитектуры. 


УПРАЖНЕНИЯ 

23.1. Поясните назначение следующих команд оптимизированной версии 
учебной ПЛ-машины: 

а) 10100100 

б) 00100011 на лексическом уровне 1 

в) 00000011 на лексическом уровне 1 

г) 00100011 на лексическом уровне 3 

д) 00000011 на лексическом уровне 3 

е) 01100011 на лексическом уровне 2 
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23.2. Пользуясь описанием рассмотренных выше команд SNAME, SLOAD 
и LITERAL учебной ПЛ-машины, попытайтесь определить коды операций 
других команд. 

23.3. Выполните компилирование второй программы, написанной на языке 
учебной ПЛ-машины (гл. 6), в предположении, что в вашем распоряжении 
находится оптимизированный вариант машины. Сравните полученные резуль¬ 
таты по занимаемому объему памяти с программой на рис. 6.4. 

23.4. Положим, что набор команд некоторой машины ориентирован на 
язык программирования более высокого уровня, чем соответствующий набор 
команд другой машины. Поясните, большими или меньшими возможностями 
по оптимизации использования пар команд обладает первая машина. 

23.5. Определите реальную среднюю информационную емкость кода опе¬ 
рации, который используется в наборе из пяти команд, если вероятность по¬ 
явления команд в программе равна 0,5; 0,3; 0,1; 0,05 и 0,05 соответственно. 
Предполагается, что порядок следования команд не зависит от их типа. Како¬ 
ва будет избыточность при фиксированном 3-битовом коде операции? Как из¬ 
менится действительная средняя информационная емкость при наличии зави¬ 
симости между командами, т. е. если после появления какой-либо команды 
вероятность появления следующей команды не соответствует указанным выше 
значениям? 

23.6. Хотя для машины SWARD сопоставлялись только три способа коди¬ 
рования операций, существует много других решений этой задачи. Предложи¬ 
те представление кода операций для 14 команд посредством 1 токен, для 
28 команд—посредством 2 токен, а для 56 — посредством 3 токен. 

23.7. Сравните полученный в предыдущем упражнении способ кодирова¬ 
ния с тремя способами, рассмотренными выше, и определите, какой из них 
лучше. 

23.8. Укажите условия, при которых для машины с фиксированным 8-би¬ 
товым кодом операции значение Н равно 8. 

23.9. Определите, сколько 4-, 6- и 10-битовых кодов операций может бытъ 
задано при использовании метода кодирования операций 4—6—10 примени¬ 
тельно к ЭВМ В1700 фирмы Burroughs, ориентированной на язык SDL. 

23.10. Поясните способ кодирования ссылок команд перехода процессора 
іАРХ 432 и укажите, как можно было бы усовершенствовать этот способ. 

23.11. Поясните способ кодирования адресных ссылок на локальные пе¬ 
ременные в процессоре іАРХ 432 и укажите, как можно было бы усовершен¬ 
ствовать этот способ. 

23.12. Как вы думаете, часто ли будет появляться приводимая ниже по¬ 
следовательность команд при работе процессора ІАРХ 432? Если часто, то 
укажите возможные пути оптимизации набора команд этой машины. 

INCREMENT-SHORT-ORDINAL 1,1 
EQUAL-SHORT-ORDINAL I.UPPER, STACK 

BRANCH-FALSE STACK, $TOP 
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ГЛАВА 24 

ПРАКТИЧЕСКИЕ РЕКОМЕНДАЦИИ 
ПО ПРОЕКТИРОВАНИЮ АРХИТЕКТУРЫ ЭВМ 

До сих пор в этой книге основное внимание было сосредоточе¬ 
но на принципах организации архитектуры ЭВМ, позволяющих 
сократить традиционные семантические разрывы. Для иллюст¬ 
рации этих принципов использовались описания реально суще¬ 
ствующих машин или проектов таких машин. Однако мало что 
было сказано о методологии самого процесса проектирования 
архитектуры ЭВМ. Поэтому представляется естественным за¬ 
вершить книгу кратким обсуждением некоторых задач и средств 
проектирования архитектуры вычислительных машин. 

ВОПЛОЩЕНИЕ ПРИНЦИПА КОНЦЕПТУАЛЬНОГО 
ЕДИНСТВА В АРХИТЕКТУРЕ 

В вычислительной технике термин «концептуальное единство» 
впервые занял прочное место в лексиконе разработчиков внеш¬ 
них интерфейсов средств программного обеспечения ЭВМ [1], 
хотя это понятие в равной мере применимо как к архитектуре 
ЭВМ, так и к другим отраслям знаний. Понятие «концептуаль¬ 
ное единство» является синонимом понятий однородности, уни¬ 
фицированности, единообразия. Применительно к архитектуре 
ЭВМ это означает завершенность и регулярность структуры, 
сведение к минимуму особых, или исключительных, ситуаций. 
При знакомстве с архитектурой, в основу которой положен ука¬ 
занный принцип, должно создаваться впечатление, что она за¬ 
думана, спроектирована и реализована как бы одним чело¬ 
веком. 

Воплощение принципа концептуального единства в архитек¬ 
туре ЭВМ имеет большое значение по крайней мере по четы¬ 
рем причинам. Во-первых, благодаря высокой степени однород¬ 
ности структуры и минимизации особых ситуаций в системе 
уменьшается количество возможных ошибок при ее реализации. 
Во-вторых, удешевляется стоимость составных частей системы, 
например процессора, поскольку высокая степень регулярности 
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выполняемых системой функций позволяет реализовать их, ис¬ 
пользуя одни и те же аппаратные средства (в режиме разде¬ 
ления времени). В-третьих, значительно упрощается программи¬ 
рование, или генерирование кодов. Действительно, отклонения 
от действия того или иного принципа организации на всю систе¬ 
му полностью сопряжено с появлением в системе большого чис¬ 
ла особых ситуаций, что приводит к увеличению времени прог¬ 
раммирования, возрастанию вероятности появления ошибок и 
усложнению процесса отладки программ на языке ассемблера. 
Если концептуальное единство организации вычислительной си¬ 
стемы не является ее неотъемлемой характеристикой, т. е. если 
принцип реализован локально (в той или иной части системы), 
это может привести к существенному увеличению части компи¬ 
лятора, выполняющей функции генератора объектного кода. 
В-четвертых, большое количество особых ситуаций, предусмат¬ 
риваемых архитектурой системы, может вызвать снижение эф¬ 
фективности программ из-за возникновения трудностей при реа¬ 
лизации оптимизирующих возможностей компиляторов в про¬ 
цессе обработки особых ситуаций. 

Такие принципы организации архитектуры ЭВМ, как теговая 
память и соответствующий набор команд, инвариантных к типу 
обрабатываемых данных, одноуровневая память, объекты и об¬ 
щий для всех команд механизм адресации, являются путями 
решения проблемы концептуального единства. Однако лучше 
всего понять важность принципа концептуального единства 
можно, анализируя примеры, где этот принцип не соблюден. 
Приведем несколько примеров указанного типа, принятых при 
разработке архитектуры Системы 370. 

1. Машина располагает командами преобразования целых 
двоичных чисел в целые десятичные и обратного преобразова¬ 
ния, но аналогичные команды преобразования данных другого 
типа (например, чисел с плавающей точкой, десятичных пра¬ 
вильных дробей, символьных строк) отсутствуют. 

2. Многие команды, использующие набор регистров общего 
назначения, должны оперировать двумя смежными регистрами. 
В команде требуется указание регистра с младшим номером, 
причем этот номер должен быть четным. 

3. Если при выполнении команды CONVERT-TO-BINARY 
возникает переполнение, регистрируется особая ситуация «деле¬ 
ние с плавающей точкой». 

4. Существуют два представления двоичных целых чисел: 
с помощью слова (32 бит) и полуслова (16 бит). Почти все 
команды, оперирующие словами (например, LOAD, STORE, 
ADD, SUBTRACT, MULTIPLY), имеют соответствующие коман¬ 
ды для работы с полусловами; исключение составляет команда 
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5. Некоторые команды (например, команда MOVE CHA¬ 
RACTER LONG) используют четыре регистра общего назначе¬ 
ния, что усложняет решение задачи оптимизации распределения 
регистров. 

6. Название почти всех регистров общего назначения отра¬ 
жает их функциональную задачу. Однако имеется команда 
TRANSLATE-AND-TEST, которая может работать только с ре¬ 
гистрами 1 и 2. 

7. Существует команда HALVE (ДЕЛЕНИЕ ПОПОЛАМ) 
для чисел с плавающей точкой, но аналогичные команды для 
двоичных целых или десятичных чисел отсутствуют. 

8. Вследствие выполнения одних команд устанавливается 
признак результата, после выполнения других не уста¬ 
навливается; критерий разделения команд по этому признаку 
носит почти случайный характер. Так, при выполнении команд 
сложения и вычитания признаку результата присваивается зна¬ 
чение, а при реализации команд умножения и деления он игно¬ 
рируется; при выполнении команды LOAD-POSITIVE признак 
устанавливается, а при выполнении команды LOAD — нет. Пос¬ 
ле сложения двоичных или десятичных целых признак резуль¬ 
тата может быть проверен на переполнение, а после сложения 
чисел с плавающей точкой такая проверка не производится. 


ОРТОГОНАЛЬНОСТЬ ПРИНЦИПОВ АРХИТЕКТУРЫ 

В то время как принцип концептуального единства гласит: 
«Объекты должны быть однородными», принцип ортогонально¬ 
сти формулируется следующим образом: «Объекты должны 
иметь свои отличительные характеристики». Эти два принципа 
не противоречат друг другу, поскольку по-разному определяют 
понятие «объекты». Применительно к требованию ортогональ¬ 
ности понятие «объекты» означает типы данных, команды и 
другие специфические элементы архитектуры ЭВМ. Что касает¬ 
ся концептуального единства, то в данном случае под объекта¬ 
ми подразумеваются принципы и средства, с помощью которых 
обеспечивают манипулирование типами данных, командами 
и т. п. 

Свойство ортогональности предполагает «взаимную перпен¬ 
дикулярность» принципов организации архитектуры ЭВМ и 
преследует перечисляемые ниже цели: 

1) поддержание числа базовых принципов архитектуры на 
некотором минимальном уровне (в разумных пределах); 

2) достижение максимальной независимости этих принципов; 

3) избежание «излишеств» в средствах, которые реализуют 
принципы, заложенные в основу архитектуры машины. 
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Архитектуре, принципы организации которой не удовлетво¬ 
ряют в должной степени требованию ортогональности, присуще 
«перекрытие» этих принципов. Следствием этого является на¬ 
личие в машине не имеющих особой практической пользы, но 
красиво выглядящих функциональных взаимосвязей в виде, на¬ 
пример, 17 различных способов очистки регистра или прираще¬ 
ния его содержимого. Если же принципы архитектуры в значи¬ 
тельной мере удовлетворяют требованию ортогональности, то 
соответствующая машина того же уровня сложности и стоимо¬ 
сти способна предоставить большие функциональные возмож¬ 
ности. 


АДЕКВАТНОСТЬ АРХИТЕКТУРЫ ТРЕБОВАНИЯМ 
«ВНЕШНЕГО МИРА» 

Содержание всех предыдущих глав книги должно было посте¬ 
пенно привести читателя к заключению о необходимости фор¬ 
мирования архитектуры ЭВМ на основе требований внешней 
среды, которую машине надлежит «обслуживать». Так, архитек¬ 
тура должна определяться используемым языком программиро¬ 
вания: его структурой, особенностями применения, типом ре¬ 
шаемых задач. Большинство свойств машин традиционной ар¬ 
хитектуры только в незначительной степени удовлетворяет этим 
требованиям. 

Характерным примером является вопрос о признаках резуль¬ 
тата. Можно утверждать, что они не только малополезны в язы¬ 
ках высокого уровня, но просто нежелательны. В программе на 
языке высокого уровня признаки результата используются толь¬ 
ко при вычислении логических выражений —в операторах IF и 
операторах присваивания. Однако признак результата устанав¬ 
ливает также ряд команд, несвязанных с обработкой логических 
выражений, например в Системе 370 это команды ADD, LOAD- 
POSITIVE и многие другие. Компилятор эти признаки резуль¬ 
тата не использует, но сам факт их установки увеличивает за¬ 
траты, связанные с практической реализацией команд. Так, 
анализ программ для машины PDP-11 [2] показывает, что при 
использовании команд, основным назначением которых не яв¬ 
ляется формирование признака результата (в эту категорию не 
входят команды сравнения), значения признака результата не 
применяются на протяжении 92% времени работы программы. 

Другим примером неадекватности архитектуры традицион¬ 
ных машин требованиям обслуживаемого ими «внешнего мира» 
является описываемая в гл. 23 раздельная реализация опера¬ 
ций сравнения и передачи управления. 

Еще одним примером указанной выше неадекватности мо¬ 
жет служить ситуация, когда требуется вычислить логическое 
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выражение и использовать полученный результат для каких-то 
целей, не связанных с передачей управления. В подобных слу¬ 
чаях механизм оперирования признаком результата оказывает¬ 
ся весьма неудобным. Обычно признак результата является 
частью слова состояния процессора и не может обрабатываться 
как данные. Например, в Системе 370 для использования при¬ 
знака результата в качестве данных необходимо либо приме¬ 
нение последовательности команд условного перехода к коман¬ 
дам, формирующим признак результата как некоторую величи¬ 
ну, соответствующую выбранной ветви перехода, либо генериро¬ 
вание прерывания, либо выполнение «фиктивной» команды 
BRANCH-AND-LINK, сохраняющей в регистре признак резуль¬ 
тата. 

Команды сдвига —еще один пример возможностей, предо¬ 
ставляемых архитектурой ЭВМ, но находящих лишь незначи¬ 
тельное практическое применение. При наличии команд умно¬ 
жения и деления команды сдвига вряд ли будут широко исполь¬ 
зоваться, если основным средством программирования являются 
языки высокого уровня. Кстати, общим заблуждением многих 
разработчиков и типичной ошибкой, которую можно обнару¬ 
жить в компиляторе, является представление о том, что сдвиг 
вправо эквивалентен делению [3]. В арифметике, построенной 
на двоичном дополнительном коде, сдвиг вправо дает резуль¬ 
тат, совершенно не согласующийся с правилами целочисленной 
арифметики для большинства языков программирования. Так, 
например, при делении —1 на 2 путем сдвига результат равен 
— 1, в то время как, согласно требованиям большинства язы¬ 
ков программирования, результат должен быть равен 0. 


ОПТИМИЗАЦИЯ ВЫЧИСЛИТЕЛНЫХ СРЕДСТВ 
ПО КРИТЕРИЮ ЧАСТОТЫ ИХ ИСПОЛЬЗОВАНИЯ 

В предыдущей главе было показано, что частота использования 
команд, данных и адресов распределена по диапазону возмож¬ 
ных значений крайне неравномерно. В подобных случаях обыч¬ 
но целесообразен поиск оптимальных решений, даже если это 
приводит к определенным нарушениям требований единообра¬ 
зия и ортогональности архитектуры ЭВМ. 

Для оптимизации необходимо располагать статистическими 
данными относительно того, как будет использоваться маши¬ 
на данной архитектуры (или как используются уже существу¬ 
ющие машины той или иной архитектуры либо языки програм¬ 
мирования). 

При анализе машинных команд основное внимание должно 
уделяться следующим наиболее употребительным операциям: 
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1. Копирование значения константы или переменной в поле 
другой переменной (например, А: = В). 

2. Добавление к значению переменной некоторой величины, 
являющейся чаще всего небольшой по значению константой 
(обычно добавляется 1). 

3. Сравнение двух величин на равенство и условный пере¬ 
ход к точке программы, расположенной на небольшом расстоя¬ 
нии за точкой ветвления. Часто один из операндов сравнения 
является константой 0 или 1. 

Конечно, оптимизация не должна ограничиваться только эти¬ 
ми операциями, однако их следует иметь в виду при выборе 
направления работы. 

Обычно оптимизация влечет за собой появление дополни¬ 
тельных особых ситуаций, что на первый взгляд не согласует¬ 
ся с некоторыми предыдущими рекомендациями. Однако сле¬ 
дует стремиться к стиранию принципиальных различий между 
так называемыми особыми и типичными ситуациями. Пример 
прямо противоположного решения — команда приращения в 
ЭВМ PDP-11 [2]. Хотя может показаться, что она представля¬ 
ет собой оптимизированный вариант команды сложения, резуль¬ 
тат ее выполнения не полностью совпадает с результатом обыч¬ 
ного прибавления 1. Побочные эффекты, производимые этими 
двумя командами, в частности установка флага переноса, раз¬ 
личные. 

Отметим, что оптимизация, базирующаяся на неравномерно¬ 
сти частоты использования вычислительных средств, как и мно¬ 
гие другие идеи, может быть отнесена к предложениям, выска¬ 
занным фон Нейманом: «Мы хотели бы ввести в машину в ви¬ 
де электронных схем только такие логические структуры, кото¬ 
рые либо необходимы для функционирования полноценной сис¬ 
темы, либо очень удобны, поскольку часто используются...» 


ПРОЕКТИРОВАНИЕ ВЫЧИСЛИТЕЛЬНОЙ СИСТЕМЫ 
С УЧЕТОМ ЕЕ ВОЗМОЖНОГО РАСШИРЕНИЯ 

Возможность расширения архитектуры вычислительной систе¬ 
мы при соблюдении требования совместимости создаваемых мо¬ 
делей является еще одной важной проблемой, общие рекомен¬ 
дации по решению которой сформулировать нелегко. 

Помимо прочего способность системы к расширению предпо¬ 
лагает отказ от наложения произвольных ограничений на ко¬ 
личество типов команд и данных, а также на максимальные 
значения адресов. Некоторые приемы оптимизации времени вы¬ 
полнения программ и объема занимаемой ими памяти, рассмот¬ 
ренные в гл. 23 (например, оптимизация представления кодов 
операций, адресов и данных, основанная на неравномерности 
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распределения частот их использования), могут оказаться по¬ 
лезными и при решении проблемы расширения архитектуры вы¬ 
числительной системы. 

Конечно, при решении этого вопроса, как и многих других, 
необходимо «чувство меры». Стремление к предоставлению вы¬ 
числительной системе наибольших возможностей по ее расши¬ 
рению должно согласовываться со всеми другими целями для 
достижения оптимального сбалансированного решения. 


НЕЗАВИСИМОСТЬ АРХИТЕКТУРЫ СИСТЕМЫ 
ОТ УСЛОВИИ ЕЕ КОНКРЕТНОЙ РЕАЛИЗАЦИИ 

Идеальным следует считать такое решение, при котором архи¬ 
тектура системы накладывает лишь незначительные ограниче¬ 
ния на процессор, реализующий ее основные функции. Напри¬ 
мер, архитектура должна допускать практическую реализацию 
широкого набора вычислительных машин различной производи¬ 
тельности и стоимости — семейства совместимых процессоров. 
По-видимому, архитектура высокого уровня в большей мере от¬ 
вечает этому требованию, чем архитектура традиционных сис¬ 
тем. Например, команды, которыми располагает архитектура 
высокого уровня, обладают большими возможностями для рас¬ 
параллеливания вычислительного процесса. При этом допус¬ 
кается и последовательное выполнение этих команд на более 
дешевых и менее производительных моделях вычислительной 
системы при сохранении возможностей создания варианта сис¬ 
темы с высоким уровнем параллелизма вычислений. 


НЕЗАВИСИМОСТЬ АРХИТЕКТУРЫ СИСТЕМЫ 
от ТЕХНОЛОГИЧЕСКОЙ БАЗЫ 

Многие системы проектируются в расчете на длительное ис¬ 
пользование и поэтому должны быть приспособлены к условиям 
изменяющейся технологии и экономики. Так, объем памяти 16М 
байт представлялся вполне разумным верхним пределом во вре¬ 
мя разработки Системы 360, но с тех пор 24-битовая адреса¬ 
ция стала «занозой в теле» фирмы IBM. Учитывая, что уже в 
те годы существовали идеи использования виртуальной памяти 
и режима разделения времени, что 32-битовая адресация не 
менее сложным образом реализуется архитектурой этих ма¬ 
шин, а также то обстоятельство, что технология производства 
интегральных схем была уже близкой перспективой, нельзя счи¬ 
тать разумным решение об использовании 24-битовой адресации 
для больших систем. 

Поскольку технология изготовления логических схем и за¬ 
поминающих устройств развивается довольно быстро, следует 
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избегать решений, жестко ориентированных на использование 
технологической базы, доступной к моменту практической реа¬ 
лизации системы. Это хорошо согласуется с тем, что на этапе 
разработки архитектуры системы такие ее характеристики, как 
потенциальная адресация и одноуровневая память, не требу¬ 
ют указания объема, типа и характеристик физически реали¬ 
зуемой запоминающей среды. 

ФОРМАЛИЗОВАННОЕ ОПИСАНИЕ АРХИТЕКТУРЫ 

Еще одним важным вопросом проектирования архитектуры яв¬ 
ляется использование формализованного языка описания спе¬ 
цификаций системы как дополнение к обычному словесному 
описанию технических характеристик ЭВМ. Это дает следую¬ 
щие преимущества: во-первых, формализованное описание сис¬ 
темы более точное и определенное, чем словесное описание; во- 
вторых, если формализованное описание является семантичес¬ 
ким или алгоритмическим определением архитектуры, его мож¬ 
но использовать как руководство при проектировании процессо¬ 
ра на этапе реализации данной архитектуры; в-третьих, если 
язык описания пригоден для работы на ЭВМ (ею выполняем), 
то он может служить моделью архитектуры для изучения ее 
рабочих характеристик и проверки ее практической реализуе¬ 
мости; в-четвертых, наличие подобного языка описания позво¬ 
ляет использовать технику корректировки программ для оцен¬ 
ки алгоритмов архитектуры проектируемой машины. 

Наиболее известным языком описания является язык ISP 
[5]. К сожалению, он в основном ориентирован на описание 
синтаксиса архитектуры, например форматов команд и данных; 
для описания ее семантики этот язык мало подходит. Можно 
назвать еще несколько подобных языков, применявшихся для 
решения аналогичных задач. Так, учебная ПЛ-машина была 
определена с помощью процедурного языка MDL [6], Система 
360 — с использованием языка APL [7], а для архитектуры 
машины SWARD был разработан расширенный диалект языка 
ПЛ/1. В процессе создания алгоритмического описания маши¬ 
ны SWARD было обнаружено 13 требующих решения проблем, 
которые остались незамеченными при словесном описании ма¬ 
шины. 


МЫСЛЕННОЕ КОМПИЛИРОВАНИЕ 

КАК СРЕДСТВО ПРОЕКТИРОВАНИЯ АРХИТЕКТУРЫ 

Много раз в этой книге мысленное компилирование програм¬ 
мы, написанной на языке высокого уровня, использовалось 
как средство изучения архитектуры машины. Этот прием может 
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быть очень эффективным при разработке архитектуры, посколь¬ 
ку дает возможность анализировать возможные варианты и 
выявлять просчеты. 


РЕАЛИЗУЕМОСТЬ ЯЗЫКОВ ПРОГРАММИРОВАНИЯ 
МАШИНОЙ ОПРЕДЕЛЕННОЙ АРХИТЕКТУРЫ 

Для машины фон Неймана обычно справедливо следующее: 
если машина допускает компилирование программы, написан¬ 
ной на каком-либо языке программирования, то на этой маши¬ 
не можно компилировать программы, создаваемые на любых 
существующих языках программирования. Таким образом, при 
разработке традиционной архитектуры вопрос может стоять 
лишь об эффективности компилирования программ и очень ред¬ 
ко или вообще никогда — о принципиальной возможности ком¬ 
пилирования с конкретного языка. 

Однако для машин с архитектурой высокого уровня вопрос 
о возможности компилирования с различных языков является 
новым и важным. Поскольку в этих машинах устранена опас¬ 
ная универсальность, присущая машинам фон Неймана, а сов¬ 
ременные языки разработаны с расчетом на работу с машина¬ 
ми фон Неймана, вполне может оказаться, что компилирование 
каких-либо языковых конструкций окажется невозможным. 

Вопрос о правильности использования языка программиро¬ 
вания решается выяснением, допускает ли данная архитектура 
компилирование программ, написанных на этом языке. Нефор¬ 
мальным методом, который может быть использован для этой 
цели, является проверка каждой конструкции языка (например, 
каждого типа данных, оператора, знака операции) на соответ¬ 
ствие одной или нескольким конструкциям архитектуры, т. е. 
на реализуемость ими. В частности, при сопоставлении возмож¬ 
ностей языка ПЛ/1 и учебной ПЛ-машины становится ясно, что 
разработка для последней компилятора языка ПЛ/1 невозмож¬ 
на, поскольку некоторые важные элементы структуры языка 
ПЛ/1 не могут быть реализованы. При сопоставлении возмож¬ 
ностей языка ФОРТРАН и машины SWARD видно, что на по¬ 
следней нельзя выполнить некоторые типы оператора 
EQUIVALENCE, например объявление эквивалентными пере¬ 
менных целого и вещественного типов. 


ОТКАЗ ОТ КОЛЛЕКТИВНОГО 
ПРИНЯТИЯ РЕШЕНИЙ 

Провал многих проектов разработки архитектуры ЭВМ, новых 
языков программирования и операционных систем связан с кол¬ 
лективным подходом к выработке решений. Хотя участие неко- 
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торого комитета в процессе работы над проектом представляет¬ 
ся вполне разумным (например, с целью внесения новых идей, 
изучения первоначальных решений, оценки возможных вариан¬ 
тов), принятие окончательных решений, как и составление спе¬ 
цификаций законченного проекта, в идеальном случае должно 
осуществляться одним лицом. «При проектировании суперком¬ 
пьютеров ни один коллектив не добьется таких успехов, как 
один высококвалифицированный энергичный разработчик. Яс¬ 
ное понимание задач и цельность видения оказываются в ходе 
большой работы более весомыми, чем ошибки, которые может 
допустить один человек» [8]. 
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ОТВЕТЫ К УПРАЖНЕНИЯМ 


1.1. И да и нет. Да, поскольку большинство существующих систем разра¬ 
батывались именно в такой последовательности, хотя полученные в конечном 
счете результаты были, как правило, далеки от оптимальных. Если бы вопрос 
начинался со слов «Обязательно ли», то ответ должен быть отрицательным, 
поскольку трудно сформулировать требования, установить критерии и при¬ 
нять компромиссные решения, когда архитектура системы еще не определена. 

1.2. В идеале это должен быть человек, обладающий знаниями всех пере¬ 
численных специалистов. Если необходимо сделать выбор, то, вероятно, раз¬ 
работчик компиляторов является наиболее подходящей кандидатурой. При¬ 
кладной программист, по всей видимости, мало знаком с архитектурой ЭВМ. 
Разработчик операционной системы склонен оказывать отрицательное влия¬ 
ние на выбор архитектуры, поскольку, хотя результаты разработки опера¬ 
ционной системы и являются важными, конечная цель проектирования боль¬ 
шинства систем — обеспечение эффективности разработки и выполнения при¬ 
кладных программ пользователей. Инженер, проектирующий центральный 
процессор, вероятно, самый плохой кандидат, если только не имеет достаточ¬ 
ного представления об интерфейсе аппаратных средств с программным обес¬ 
печением, т. е. не знаком с программным обеспечением. 

1.4. Для Системы 370 фирмы IBM S=240 и М=768, для микропроцессо¬ 
ра 8080 фирмы Intel S=192 и М=488. Заметим, что здесь должны быть при¬ 
няты определенные допущения. Так, должно быть определено, как произво¬ 
дится выборка команды: 1) команда выбирается полностью; 2) выбирается 
содержимое только тех полей команды, которые необходимы для выполнения 
операции (например, если условный переход не должен выполняться, то про¬ 
цессору не нужно выбирать содержимое поля адреса перехода команды). 
Приведенные ранее значения параметров S и М вычислены с учетом первого 
предположения. 

1.5. В системе, построенной на базе архитектуры семейства микропроцес¬ 
соров 8080 фирмы Intel, объем памяти, требуемый для выполнения про¬ 
грамм, составляет приблизительно 80% объема памяти в Системе 370, причем 
программы выполняются на 35% быстрее. Разумеется, необходимо проанали¬ 
зировать большое число примеров программ, прежде чем сделать это заклю- 


1.О. 0,0“/о. 

1.7. Основная причина—использование микропроцессорами 8080 фирмы 
Intel 8-битовых команд, выполняющих приращение содержимого регистра или 
пары регистров на 1 (наиболее часто встречающаяся операция). В Систе¬ 
ме 370 для той же цели требуется выполнение 32-битовой команды. 

1.8. Нет. Убедительным подтверждением этого является организация пе¬ 
ресылки нескольких значений данных из одной области памяти в другую 
(часто используемая операция). В Системе 370 такую операцию выполняет 
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одна команда, а в микропроцессорах 8080 фирмы Intel для этого должен 
быть составлен цикл из нескольких команд. 

1.9. Как ни странно, но критерий стоимости. (Странно, потому что произ¬ 
водителем ЭВМ является промышленность.) Архитектурные решения влияют 
на стоимость процессора, требуемый объем памяти, стоимость разработки 
компиляторов, системного программного обеспечения (в том числе операцион¬ 
ных систем) и прикладных программ. Перечисленные затраты связаны между 
собой достаточно сложным образом, причем соотношения до сих пор не были 
широко исследованы. 

2.1. 1. Массив может быть многомерным, но память машины фон Неймана 
является линейной, и, следовательно, компилятор должен преобразовывать 
массив в вектор. 

2. Размеры элементов в разных массивах могут быть различными, однако 
аппаратные средства вычислительной системы обычно предоставляют только 
механизм индексирования, ориентированный на доступ к слову или байту. 

3. Возможно выполнение операций сразу над всем массивом, однако мо¬ 
дель памяти машины фон Неймана предполагает единовременную обработку 
только слова. 

4. Кросс-секции предусматривают обращения к группам данных, распо¬ 
ложенных в различных, несмежных участках памяти; однако модель памяти 
фон Неймана этого не допускает. 

5. Согласно принципам архитектуры машины фон Неймана, модель памя¬ 
ти—это один большой вектор, охватывающий всю запоминающую среду ма¬ 
шины; при этом отсутствуют какие-либо явно обозначенные границы место¬ 
положения совокупностей данных. Все это указывает на неявный (для моде¬ 
ли памяти машины) характер описания таких моделей данных или структур, 
как массивы; причем эти описания даются в программе. 

2.2. Попытки слишком сильного сокращения семантического разрыва мо¬ 
гут на практике привести к обратному эффекту. Предположим, например, что 
при разработке архитектуры машины удалось свести почти к нулю ее семан¬ 
тический разрыв с языком ПЛ/1. Это может оказаться эффективным для 
программирования на указанном языке, но не исключено (и даже весьма 
вероятно), что при этом увеличится семантический разрыв между архитекту¬ 
рой и другими языками (такими, как Ада, Паскаль, КОБОЛ) по сравнению 
с разрывом между языками и архитектурой традиционных машин. Поэтому 
одна из возможных стратегий при решении подобной проблемы для «много¬ 
язычной» вычислительной системы — сокращение разрыва между ее архитек¬ 
турой и семантическими характеристиками, являющимися общими для языков 
программирования. Существуют и другие стратегии решения этой проблемы, 
но они рассматриваются в четвертой и пятой частях книги. 

2.3. Для сокращения семантического разрыва можно рекомендовать сле¬ 
дующее: 

1) вместо памяти в виде единого последовательного адресного пространст¬ 
ва использовать запоминающую среду, которая бы более походила на мо¬ 
дель памяти языков программирования; 

2) память должна допускать представление ее модели как многомерного 
пространства; 

3) машина должна отличать данные от программ по форме их представ¬ 
ления в памяти; 

4) характеристики данных следует хранить вместе с данными, вместо того 
чтобы включать их в качестве описаний в программы. 

2.4. Если для представления чисел используется двоичная система счисле¬ 
ния, то двоичные эквиваленты десятичных чисел являются только их прибли¬ 
женным представлением (например, десятичной дроби 0,1 эквивалентна бес¬ 
конечная дробь 0.0001100110011..., подлежащая усечению). 

2.5. 20,4%. Отношение количества двоичных разрядов, занимаемых деся¬ 
тично кодированными числами, к количеству разрядов их двоичных эквива- 
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лентов равно 4 log 2 (в предположении, что равновероятны все значения чи¬ 
сел). 

2.6. Такое решение позволит достичь немногого, поскольку частота вызо¬ 
ва процедур (требующего сохранения содержимого регистров с их последую¬ 
щим восстановлением) значительно больше, чем частота переключения про¬ 
цессов или прерываний. 

2.7. Указанное отношение равно 132/227, причем 227 регистров были за¬ 
гружены в процессе выполнения программы, но только содержимое 132 из 
них было использовано. Если же учесть, что команды BALR, LTR и СѴВ то¬ 
же загружают регистры, то упомянутое отношение окажется еще меньше. 

3.1. Возможны следующие подходы: 

1) ориентация архитектуры машины на использование только одного язы¬ 
ка программирования; 

2) при ориентации архитектуры на несколько языков программирования 
использование только тех семантических характеристик этих языков, которые 
являются для них общими (т. е. отказ от ориентации архитектуры на один 
конкретный язык программирования); 

3) использование мультипроцессорной конфигурации вычислительной си¬ 
стемы, каждый прцессор которой связан с конкретным языком высокого уров¬ 
ня, а операционная система выполняет функцию диспетчеризации программ 
по соответствующим процессорам; 

4) оснащение процессора набором микропрограмм, способных реализовать 
то или иное требуемое архитектурное решение, при условии, что операционная 
система выполняет функцию планировщика переключений на требуемую мик¬ 
ропрограмму (подход, реализованный в ЭВМ В1700 фирмы Burroughs); 

5) введение так называемого базового набора команд, используемого 
всеми языками программирования, и группы дополнительных наборов команд, 
учитывающий специфические требования каждого из языков (подход, реали¬ 
зованный в машине SWARD; см. часть 5). 

3.2. БЕЙСИК (широко используется в персональных ЭВМ) и РПГ (при¬ 
меняется в малых ЭВМ для коммерческих расчетов). 

4.1. Такой может оказаться конструкция языка, в котором «накладывают¬ 
ся» друг на друга или объединяются идентификаторы переменных разного 
типа; именно это осуществляет оператор EQUIVALENCE в ФОРТРАНе, пред¬ 
ложение REDEFINES в КОБОЛе и атрибут DEFINED в ПЛ/1. Например, 
операторы ФОРТРАНА 
INTEGER А 
REAL В 

EQUIVALENCE (А.В) 

назначают переменным А и В одну и ту же область памяти, допуская разме¬ 
щение в ней числа с плавающей точкой при использовании имени В и целого 
числа при использовании имени А. Однако такая практика программирования 
признана порочной, поскольку делает программу зависимой от специфики ап¬ 
паратных средств машины. По указанной причине новые стандарты упомяну¬ 
тых языков программирования, а также описания новых языков (например, 
языка Ада) запрещают применение подобных средств. 

4.3. Программа, выполняемая на машине Y, требует меньше памяти, если 
R больше чем 1,6. 

4.4. Программа для теговой машины (Y) занимает 85% того объема па¬ 
мяти, который требуется той же программе для машины X. У машины X 
команды 48-битовые, а у машины Y — 38-битовые. Средний размер операнда 
машины X составляет 32 бит, а машины Y — 40 бит. Предполагается, что на 
каждый из указанных операндов в среднем приходится пять команд. 

4.5. Это пример трудностей, с которыми сталкиваются, когда информация 
о данных полностью содержится в потоке команд. Так, в Системе 370 коман¬ 
да МѴС (ПЕРЕСЫЛКА СИМВОЛА) указывает количество байтов, подле- 
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жащих пересылке. Часто нельзя заблаговременно «связать» эту команду с 
конкретным счетчиком байтов (например, желательно задать пересылку фор¬ 
мального параметра в виде строки символов, размер которой определяется 
текущим фактическим параметром). Тогда для хранения этой величины (раз¬ 
мера) предоставляется регистр. Подлежащая выполнению команда EXECUTE 
задает команду МѴС как операнд. В результате появляется возможность 
модификации команды МѴС посредством содержимого регистра и последую¬ 
щего ее выполнения. 

4.6. Появление упомянутых «двусмысленностей» связано с моментом чте¬ 
ния следующей карты. Если имеет место обращение к части этого поля (на¬ 
пример, к восьмому символу), предполагает ли это чтение следующей карты? 
Читается ли карта при выполнении команды сравнения, использующей содер¬ 
жимое поля в качестве операнда? Как представляется и выявляется факт 
того, что очередь пуста? И, конечно, потребовался бы механизм, предотвра¬ 
щающий недопустимые записи в указанное поле. 


Адресация посредством 



регистров 

аккумулятора 

стека с безад¬ 
ресными коман- 

ресными 

°коман- 

LOAD 

R1,B 

LOAD 

В 

PUSH 

В 

PUSH 

В 

ADD 

Rl.C 

ADD 

C 

PUSH 

C 

ADD 

С 

LOAD 

R2,D 

STORE 

TEMP 

ADD 


PUSH 

D 

ADD 

R2,E 

LOAD 

D 

PUSH 

D 

ADD 

E 

MULT 

R1.R2 

ADD 

E 

PUSH 

E 

MULT 


STORE 

R1,A 

MULT 

STORE 

TEMP 

A 

ADD 

MULT 

STORE 

A 

STORE 

A 


Адресация типа память — память 


с двухадресными 
командами 

с трехадресными 
командами 

с 2/3-адресными командами 

MOVE 

ADD 

MOVE 

ADD 

MULT 

A, В 

A,C 

TEMP.D 

TEMP.E 

A,TEMP 

ADD 

ADD 

MULT 

A,B,C 
TEMP.D,E 

A,A,TEMP 

ADD 

ADD 

MULT 

A,B,C 

TEMP.D.E 

A,TEMP 


5.1. Содержимое поля типа определяет тип данных элементов массива. 

5.2. В память сегментов программ и строк данных, память таблицы сим¬ 
волических имен и память таблицы областей действия переменных. 

5.3. Содержимое памяти таблицы символических имен и памяти таблицы 
областей действия переменных. 

5.4. Указатель массива в стековой памяти данных адресует дескриптор, 
находящийся в памяти дескрипторов массива. Последний указывает местопо¬ 
ложение первого элемента массива в верхней части стековой памяти данных. 
Элементы массива в стековой памяти данных представлены дескрипторами, 
адресующими строки символов, записанные в памяти сегментов программ и 
строк данных. 


20-429 
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5.5. Максимальное число равно 16, поскольку в машине имеется 16 дис¬ 
плей-регистров. 

5.6. Изменяется содержимое стековой памяти данных и регистра — указа¬ 
теля стековой памяти данных (при распределении локальной памяти для вы¬ 
зываемой процедуры), памяти сегментов программ и строк символов (если 
вызываемая процедура использует символьные переменные), памяти стека ука¬ 
зателей сегментов программы и стека указателей активизируемых сегментов 
программы, а также регистров-указателей этих стеков и дисплей-регистров. 

5.7. Не всегда. Каждый элемент должен содержать ссылки на предшеству¬ 
ющий элемент стека, за исключением случаев рекурсивных вызовов процедур. 

6.1. DS(103) =указатель массива, DS(102) =число О, DS(101) =число 1. 
[Пояснение. DS (data stack) — стек данных.] 

6.2. Эти команды предназначены для инициализации первого элемента 
массива (с индексом 0) как дескриптора сегмента программы с адресом 700 
(сегмента, соответствующего ситуации ELSE). 

6.3. Дескриптор сегмента программы, находящийся в стеке, указывает 
местоположение вызываемого сегмента. Первой командой сегмента должна 
быть команда SCOPEID, указывающая «вход» таблицы областей действия 
переменных, относящийся к данному сегменту программы. 

6.4. Количество фактических параметров указывается в поле операндов 
команд. Количество формальных параметров процедуры определено в соответ¬ 
ствующем элементе таблицы областей действия переменных. 

6.5. Первая команда удаляет из стека неопределенную величину, возвра¬ 
щаемую после выполнения процедуры ZZZ, вторая — дескриптор косвенного 
адреса фактического параметра, помещенный в стек при выполнении команды 
с номером 34. 

6.6. Элемент таблицы областей действия переменных определяет количе¬ 
ство формальных параметров, адрес первого элемента таблицы символиче¬ 
ских имен и количество этих элементов, представляющих параметры. Фор¬ 
мальные параметры всегда описываются первыми в таблице символических 
имен, поскольку их имена первыми встречаются в процессе компилирования 
процедуры (они перечисляются в операторе PROCEDURE) . 

8.1. Очевидный недостаток — «дороговизна» внесения изменений в систе¬ 
му. Например, при добавлении в набор команд языка SPL нового оператора 
необходимо изменение конструкции части последовательностных логических 
схем транслятора. 

8.2. Производится обращение к четвертому элементу трехмерной подструк¬ 
туры, являющейся третьим элементом двумерной подструктуры, в свою оче¬ 
редь являющейся вторым элементом одномерной подструктуры X. 

8.3. Возможны оба варианта: результат может быть скаляром или струк¬ 
турой. 

8.4. 

A: |-200-300-WXYZ-null-| 


101 

100 

102 

200 


300 


WXYZ 


9.1. Внутренняя форма представления числовых данных — упакованные 
десятичные числа. Восьмибитовое поле используется для представления не 
одной цифры, а двух. 
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9.2. FD XX XX XX XX XX XX XX 

F5 30 30 30 30 30 30 30 

F6 XX XX XX XX XX XX F6 

F5 31 31 31 31 31 31 31 

F6 XX XX XX XX XX XX F6 

FF XX XX XX XX XX XX XX 

9.3. F5 31 F6 XX XX XX XX F6 

9.4. 80 YY YY YY XX XX XX XX, где YY YY YY- адрес области памя¬ 
ти, выделенной динамически для размещения числа 1234,5678. 

9.5. Из управляющего слова идентификатора с адресом 2222. Содержимое 
управляющего слова идентификатора с адресом 2272. 

10.1. Информация, идентифицирующая терминалы и пользователей, пере¬ 
дается контроллеру памяти с целью определения последних списков страниц 
пользователя, к которым относится данный запрос (например, запрос на вы¬ 
деление группы слов). 

10.2. Центральный процессор использует в качестве стека строку логиче¬ 
ской памяти. При этом операция контроллера памяти FR (см. табл. 10.2) соот¬ 
ветствует удалению данных из стека (операция POP центрального процессора). 

10.3. Если бы не было поля IGAC, то контроллер памяти должен был 
бы соединять все слова связи групп слов страницы между собой для образо¬ 
вания списка доступных для распределения групп при каждом использовании 
свободной страницы. Наличие поля IGAC позволяет контроллеру памяти до¬ 
стичь той же цели просто путем записи 1 в поле IGAC перед началом исполь¬ 
зования свободной страницы. Если страница используется длительное время, 
в течение которого ее группы распределяются и освобождаются, то содержи¬ 
мое поля IGAC в конечном счете будет увеличено до 29; после этого группы 
будут распределяться из списка доступных для распределения групп. Таким 
образом, наличие поля IGAC уменьшает время, затрачиваемое на распределе¬ 
ние памяти страниц. 

10.4. Для эффективного выполнения операции FR (см. табл. 10.2). 

10.5. Наличие этих операций объясняется потребностью контроллера памя¬ 
ти и регенератора памяти манипулировать одними и теми же списками. Если 
регенератор памяти удаляет элементы из списка областей памяти с «инфор¬ 
мационным мусором» или включает их в список областей памяти, доступных 
для распределения, и при выполнении этого контроллер памяти обращается 
к указанным спискам для выполнения запросов другого процессора, то может 
возникнуть ошибка, связанная с несогласованностью действий во времени ре¬ 
генератора памяти и контроллера памяти (в частности, область памяти мо¬ 
жет быть «утеряна» или включена сразу в несколько списков). Таким обра¬ 
зом, операции DL и RG выполняются контроллером памяти для обеспечения 
последовательной работы со списками областей памяти с «информационным 
мусором» и доступных для распределения. 

10.6. Нет. Такая ситуация возникает только при работе со строками, пред¬ 
ставляющими структуры языка SPL; память для этих строк всегда распреде¬ 
ляется из списка TPL2. Следовательно, регенератор памяти должен выпол¬ 
нять подобную процедуру только в случае, когда страница, содержащая стро¬ 
ку, включена в список TPL2. Процессор адресации данных также помогает 
регенератору памяти в выполнении данной процедуры путем присвоения еди¬ 
ничного значения биту 37 слова связи групп (табл. 10.3), если в одно из 
слов помещается адрес. 

10.7. Адреса и данные сами определяют свой тип. Поля данных начинают¬ 
ся с управляющих символов F0, FI, F2, F3 или F5, указатели подгруппы 
структуры — с управляющего символа ЕС. 

20* 



300 ОТВЕТЫ К УПРАЖНЕНИЯМ 


10.8. В системе имеется один общий список свободных (доступных для 
распределения) страниц; он содержит все нераспределенные страницы памя¬ 
ти. Для каждого пользователя предусмотрены три списка свободных областей 
памяти; в них включены страницы, содержащие группы слов, доступные для 
распределения. На каждой странице имеется один список свободных групп 
слов; в него входят все свободные, освобожденные регенератором памяти 
группы слов этой страницы- 

10.9. Элемент структуры А[2,2] содержал в данный момент скаляр 202. 
Для размещения вектора <123414321> будет выделена память строки, состоя¬ 
щей из трех слов, и указатель подгруппы структуры будет помещен в слово, 
содержащее величину 202. Кроме того, второе слово (указатель подгруппы 
структуры) в крайнем слева блоке на рис. 10.4 будет теперь содержать ин¬ 
декс 02, а его последнее поле будет адресовать указатель этой новой под¬ 
группы. 

10.10. Первые 32 слова каждой страницы не могут использоваться в ка¬ 
честве памяти для размещения данных. Они содержат заголовок страницы 
и слова связи групп слов страницы. 

12.1. Значение, равное 6. 

12.2. 16 бит (3 —код операции, 7 —поле первого операнда, 6 —поле вто¬ 
рого операнда). 

12.3. 19 бит. 

12.4. Пересылка 4-битового числа без знака 73 в область памяти, отно¬ 
сящуюся к дескриптору, индекс которого в таблице дескрипторов равен 27. 

12.6. В шестнадцатеричном представлении — число 4EF7F340. 

12.6. &**** 10.45 (в коде EBCDIC). 

12.7. Наиболее оригинальными атрибутами набора команд, ориентирован¬ 
ного на язык КОБОЛ, являются атрибуты команд, выполняющих операции 
редактирования и сравнения. Они хорошо отражают природу основного при¬ 
менения языка КОБОЛ, поскольку программы на этом языке ориентированы 
главным образом на ввод-вывод и манипулирование данными 1 ’ и выполняют 
относительно небольшой объем арифметических операций. 

14.1. Данная ячейка представляет число с плавающей точкой, равное 
—0.7493- ІО 23 . 

14.2. Результат работы компилятора — внешний модуль — представлен 
посредством строки токенов. Определение модуля для машины осуществляется 
путем выполнения команды CREATE-MODULE, одним из операндов которой 
является строка токенов, представляющая модуль. Строка (поле) токенов мо¬ 
жет быть также использована для эмуляции других архитектур; при этом 
адресное пространство машины другой архитектуры содержится в поле то¬ 
кенов. Дополнительный набор команд может содержать команду «Эмуляция 
архитектуры X». 

14.3. Массивы и записи не могут быть адресатами ячеек «параметр» ти¬ 
па D или «косвенный доступ к данным» из-за неопределенностей («двусмыс¬ 
ленностей»), которые при этом могли бы возникнуть в потоке команд (раз¬ 
личными являются адреса операндов для скаляров, массивов и записей). 
Ячейки типа D и ячейки, тип которых определяется пользователем, нельзя 
употреблять произвольным образом («смешивая» их), поскольку их назначе¬ 
ние различно. Использование ячеек типа D означает определение тех или иных 
атрибутов динамически (в зависимости от конкретных «внешних» условий). 
Введение же пользователем своих типов (для каких-либо ячеек) объясняется 
их стремлением снабдить машину дополнительными средствами контроля ти¬ 
па обрабатываемой информации. 

14.4. 1 009000F008006A. 

14.5. 100900010000090002000 (адреса операндов — это адреса записей). 


11 Имеются в виду операции пересылки, преобразования и редактирова¬ 
ния данных. —> Прим, перев. 
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14.6. Для присвоения начальных значений элементам массива в динамиче¬ 
ской части адресного пространства компилятор должен сгенерировать одну 
или несколько команд у каждой точки входа в модуль. Иначе неоднозначно 
решается задача присвоения начальных значений элементам массива в стати¬ 
ческой части адресного пространства. Одним из методов является предъявле¬ 
ние к компилятору следующих требований: 1) предоставить модулю дополни¬ 
тельную точку входа; 2) сгенерировать код для присвоения начальных значе¬ 
ний именно у этой точки входа. После создания такого модуля подобную 
точку входа можно было бы назвать «редактор связей». 

14.7. Глобальная переменная представляется как ячейка «косвенный до¬ 
ступ к данным» с соответствующей ячейкой «указатель». Редактор связей 
будет инициировать содержимое ячейки «указатель» посредством команды 
LINK. При использовании области общей памяти языка ФОРТРАН или струк¬ 
туры с внешним атрибутом языка ПЛ/1 содержимым ячейки «косвенный до¬ 
ступ к данным» является запись. 

14.8. Такая ситуация может возникнуть, например, при указании в про¬ 
грамме, что значение параметра итераций цикла DO не определено при его 
окончании. Другим примером такой ситуации является присвоение в програм¬ 
ме той или иной переменной нулевого значения (отсутствия значения), как 
это делается в языке ПЛ/1 или Ада. 

14.9. 


Смещение 

01 0001E0004C0009F00121 

І5 330000000 

1Е 001 F800000 

008 6005FOOOOOOO 
014 6008В0000000000 

023 6005F0000000 

4С 02F 70101000600000AFOC)0000 

045 І70131001000000АВ008000000 

05Е 9000000000000000000000 

074 F00000A 

Ѳ7В F800000 
9F 001 С03008014023 

702F0230000046 

102F023008 

0807В014 

0407В0450230080140001 
Е053 

046 D05E013045023 %А: 

053 0А- ХЪ: 

055 С01008 

10010001 

063 202F001001 %С: 

202F001008 
5001074063 
0А 


Комментарий 

Header indices 
CAS/IAS/SIS/Faults 


N 

QUASI 

MICH 

BUFFALO 

$C10 

STAA 

ACT 3.Q.M.N 

EQBF QUASI(N),0,%A 

MOVE QUASI(N),Q 

LENGTH STAA.M 

MOVESS STAA.MICH(N),Q,M,1 


ACT 


1,Q 


MOVE 

ADD QUASI(I),I ’ 

ADD QUASI(I),Q 

ITERATE I, SC10,%C 
RETURN 


14.10. Цикл DO во второй процедуре можно было бы заменить операто¬ 
ром QUASI = QUASI + 1 -f Q; это привело бы к замене команд ITERATE и 
MOVE, а также двух команд ADD двумя командами сложения, добавляю¬ 
щими значения скаляров I и Q в массив QUASI. Такую возможность мог бы 
предоставить хороший оптимизирующий компилятор. 

17.1. Поскольку объекты доступны программам, естественно желание раз- 
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решить определенным программам оперировать объектами как абстрактными 
данными, исключая возможность анализа или модификации представления 
содержимого объектов. Например, может появиться желание дать процессу 
дескриптор доступа к порту, разрешая тем самым посылать этому порту со¬ 
общения без права анализа или реорганизации очереди запросов к последне¬ 
му. Обычно на практике только программа управления типами для объекта 
(например, операционная система, если речь идет о системных объектах) по¬ 
лучает дескрипторы доступа с правами доступа для объектов. 

17.2. Сегменты данных. 

17.3. Поскольку структура данных портов та же самая, команду SEND 
можно выполнять как для порта диспетчеризации, так и для порта связи. По¬ 
сылка процесса в порт диспетчеризации—это один из способов пуска процесса. 

17.4. Потому что каждому процессу предоставляется только одно средст¬ 
во переноса данных (один транспортер). 

17.5. Функции этих объектов схожи (например, объект «управление дес¬ 
криптором» расширяет права доступа в дескрипторе доступа с целью выпол¬ 
нения операций над объектом «от имени» источника обращения к объекту). 
Однако объект «управление дескриптором» определяет такой объект, манипу¬ 
лирование которым возможно только как системным объектом. Поэтому объект 
«управление дескриптором» не может отличить сегмент данных расширенного 
типа X от сегмента данных типа Y (оба воспринимаются им как сегменты 
данных общего типа). Итак, при использовании объектов «управление дес¬ 
криптором» и средств расширения прав доступа, программа управления типа¬ 
ми может быть дезориентирована и направлена на выполнение операций над 
объектом, тип которого не соответствует этим операциям. 

17.6. Если используется глобальный объект «ресурсы памяти», то таковой 
является таблица объектов, дескриптор доступа которой находится в сегменте 
доступа объекта «ресурсы памяти». При использовании объекта «ресурсы па¬ 
мяти», локального по отношению к процессу, таковой является таблица объ¬ 
ектов, дескриптор доступа которой находится в сегменте доступа процесса. 

17.7. Прежде всего это делается из соображений защиты от несанкциони¬ 
рованного доступа. Бит младшего разряда в дескрипторе доступа выполняет 
роль индикатора такой защиты. Если в новых сегментах доступа ему не при¬ 
своено нулевое значение, появляется возможность изменения (что недопусти¬ 
мо) потенциальных адресов. Кроме того, присвоение нулевых значений ука¬ 
занным битам позволяет машине в дальнейшем обнаруживать попытки ис¬ 
пользования неопределенных дескрипторов доступа (которые являются скорее 
ошибками программирования, а не попытками нарушения установленных пра¬ 
вил санкционированного доступа). 

17.8. Такая ситуация возникает при желании предоставить процессу воз¬ 
можность обрабатывать ошибки, возникающие при его протекании (т. е. без 
направления процесса в порт обработки ошибок). Очевидно, что такую воз¬ 
можность желательно предоставить процессу операционной системы, прини¬ 
мающему процессы из порта обработки ошибок. 

17.9. Такие ситуации возникают, когда программа обработки ошибок дол¬ 
жна выполнять операции, санкционируемые подпрограммой, содержащей ошиб¬ 
ку с целью разрешения возникшей особой ситуации (например, переполнения); 
в подобных случаях программа обработки ошибок должна сама уточнить 
специфические характеристики контекста с ошибкой, определяющие параметры 
подлежащих выполнению операций (например, тип округления результата 
арифметической операции). 

18.1. Это объясняется двумя причинами. Во-первых, согласно определению 
данных вещественного типа, возможно групповое представление одной и той 
же величины (например, +0/—0, ненормализованные величины). Во-вторых, 
существует возможность представления данных как «не число», что может 
быть использовано средствами программного обеспечения для обозначения 
переменной, не получившей начального значения. 
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18.2. Это команда EQUAL-ORDINAL. Ее первый операнд расположен со 
смещением 9А в сегменте данных «константы», связанном с контекстом. Вто¬ 
рой операнд имеет форму А(І), где А — вектор порядковых чисел, начало 
которого совпадает с началом сегмента данных, местоположение которого 
определяется дескриптором доступа, расположенным в точке с индексом 3F 
в сегменте доступа к элементу 3. I — это короткое порядковое число (как и 
все индексы векторов) в сегменте данных «контекст» со смещением 1Е. Тре¬ 
тий операнд — результат сравнения — расположен на вершине стека. 

Отдельные части кода команды (анализ начинается справа) имеют следу¬ 
ющее назначение: 


1010 

1100 

00 

00 

1 

00 

0001 

0000000010011010 

10 

01 

о 

11 

00000000111111 

00 

о 

о 

00 

0000 

0001110 

000 


Класс: три операнда длиной 32, 32 и 8 
Формат: операнды 1 и 2 — ссылки 1 и 2; 
операнд 3 — вершина стека 
Обращение к скаляру (ссылка 1) 
Селектор сегмента прямой короткий 
Длина смещения (16) 

Использование ВСД 0 
Индекс ВСД (для дескриптора доступа 
для сегмента данных «константы») 
Смещение (9А) 

Обращение к элементу вектора (ссыл¬ 
ка 2) 

Селектор сегмента прямой длинный 
Длина базы (0 — отсутствие базы указы¬ 
вает на начало сегмента) 

Индекс ВСД (3F) 

Индекс ВСД 3 (3F) 

Индекс косвенный общего назначения 
Селектор прямой короткий 
Длина смещения (7) 

Использование ВСД 0 
Индекс ВСД (к сегменту данных «кон¬ 
текст») 

Смещение (1Е) 

Для класса 1010 означает EQUAL 
ORDINAL 


20.1. Программа имеет следующий вид: 


MAX [ITEM(VOL)] [REG1] 

SELECT MARK (A) [ITEM: ITEM.VOL=REG1] 

CROSS-SELECT MARK(A) [EMP: EMP.DEPT = ITEM.DEPT] 
[ITEM.MKED(A)] 

ADD [EMP(SAL): (EMP.MKED(A)) AND (EMP.SAL<20000)] 
[ 100 ] 

SELECT RESET(A) [EMP] 

SELECT RESET(A) [ITEM] 

EOQ 
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20.2. В худшем случае —350 мс. В среднем задержка по времени, связан¬ 
ная с отысканием начала памяти ячеек с целью пуска программы, составит 
10 мс. Для команды МАХ требуется несколько больше, чем один оборот вра¬ 
щающегося носителя, но команда SELECT не может начать выполнение до 
тех пор, пока снова не появится начало памяти. Вот почему вклад команды 
МАХ в общую задержку составляет 40 мс. Каждая из трех команд — одной 
команды ADD и двух команд SELECT — требует 20 мс. Предполагая наихуд¬ 
шую ситуацию, при которой информация о каждом из восьми служащих на¬ 
ходится в отдельной ячейке, получаем, что для выполнения команды CROSS¬ 
SELECT требуется 220 мс. 

20.3. Такими показателями являются следующие: 1) существенное сокра¬ 
щение объема данных, пересылаемых между рассматриваемым устройством и 
основной памятью (в традиционных системах средства поиска расположены 
в центральном процессоре); 2) сокращение числа команд, выполняемых в 
центральном процессоре для программных средств управления данными; 3) от¬ 
сутствие необходимости в поиске и обновлении трактов доступа (например, 
индексов). 

20.4. «Сложные» операции в табл. 20.1 включают проверку десяти усло¬ 
вий. Однако RAP.2 не располагает десятью компараторами. Поэтому соответ¬ 
ствующие операции разделяются между несколькими командами, что в свою 
очередь требует несколько обращений к данным для завершения работы. 

20.5. Одно из возможных решений имеет следующий вид: 


SELECT 

MARK(A) [LOCATION: LOCATION.CITY 
= “MIAMI”] 

CROSS-SELECT 

MARK(A) [ACCOUNTS: ACCOUNTS. 
DISTCODE= 

LOCATION.DISTCODE] [LOCATION. 
MKED(A)] 

>AVE 

(1) [CHARGES(MlNCHARGE): 
STATUS='Q’] [REG1] 

SELECT 

RESET(A) [ACCOUNTS: PHONES^I | 
STATUS= ‘Q’ | MCHARGE=REG1] 

SUM 

[ACCOUNTS(MCHARGE): 
ACCOUNTS.MKED(A)] [REG1] 

READ-REG 

[REG1] [MYBUF] 

SELECT 

RESET(A) [ACCOUNTS] 

SELECT ' 

EOQ 

RESET(A) [LOCATION] 


20.6. В предположении, что для начала требуется в среднем 0,5 цикличе¬ 
ских просмотра, время обработки равно 10,5 просмотра; для команды 
CROSS-SELECT требуется 3 просмотра, а для команды SUM — 2 просмотра. 

20.7. После выполнения маркирования элементов отношения можно ожи¬ 
дать, что многие из маркированных элементов принадлежат одному и тому 
же отделу. В этом случае можно было бы посредством операции проектиро¬ 
вания (итерационного использования команд GET-FIRST-MARK, SELECT, 
RESET и ВС) устранить дублирующие друг друга маркированные отделы 
прежде, чем применять команду CROSS-SELECT. 

20.8. При К=5 и без предварительного выполнения операции проектирова¬ 
ния потребуется 43 сканирования (1+200/5+2), чтобы выполнить команду 
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CROSS-SELECT. Для выполнения операции проектирования — десять итера¬ 
ций команд GET-FIRST-MARK, SELECT и ВС — необходимо 30 сканирова¬ 
ний. Для реализации после этого команды CROSS-SELECT требуется 5 ска¬ 
нирований (1 + 10/5+2). В результате общее число необходимых сканирова¬ 
ний сокращается на 8. 

22.1. Следует добавить вентили типа Т во входные ветви типа Т трех 
верхних блоков соединения. Эти вентили получают сигналы управления в ре¬ 
зультате проверки отношения двух операндов по критерию «меньше или 
равно». 

22.4. Величина 42 заменяется структурой из двух величин 3,6 и 7. 

23.1. а) Команда LITERAL: поместить целое число +36 на вершину стека. 

б) Команда SNAME: поместить дескриптор косвенного адреса, соответст¬ 
вующий адресу лексического уровня 1,35, на вершину стека. 

в) Команда SNAME: поместить дескриптор косвенного адреса, соответст¬ 
вующий адресу лексического уровня 1,3, на вершину стека. 

г) Команда SNAME: поместить дескриптор косвенного адреса, соответст¬ 
вующий адресу лексического уровня 1,3, на вершину стека. 

д) Команда SNAME: поместить дескриптор косвенного адреса, соответ¬ 
ствующий адресу лексического уровня 3,3, на вершину стека. 

е) Команда SLOAD: поместить на вершину стека величину, хранимую по 
адресу лексического уровня 1,3. 

23.2. Значение первых двух битов кодов операций других команд должно 
равняться 11, в противном случае машина не могла бы безошибочно прово¬ 
дить различие между командами. 

23.4. Вероятно, меньшими, но определенный ответ дать трудно. С одной 
стороны, в машине более высокого уровня языка программирования команды 
менее примитивны, и поэтому их последовательности в большей степени зави¬ 
сят от того, как составлена исходная программа (чего нельзя сказать о по¬ 
следовательностях команд, генерируемых компиляторами при реализации той 
или иной конструкции конкретного языка программирования). Так, например, 
машина SWARD предоставляет немного очевидных возможностей для опти¬ 
мизации такого типа. С другой стороны, для машин высокого уровня языка 
программирования характерна тенденция к использованию меньшего количе¬ 
ства команд (и следовательно, меньшего количества уникальных попарных 
сочетаний команд), что повышает частоту использования конкретной пары 
команд. 

23.5. Н=1,79 бит. Избыточность равна 40%. Если существует зависимость 
последовательности появления команд, то показатель Н для потока кодов 
операций становится меньше 1,79 бит. 

23.6. Вместо того чтобы в качестве кода переключения использовать толь¬ 
ко комбинацию битов 0000, введем в качестве другого возможного значения 
этого кода комбинацию 1111. Например, пусть ХХХХ обозначает комбинацию 
из 4 бит, для которой недопустимыми являются сочетания 0000 и 1111. Тогда 
4-битовые коды операций представляются в виде ХХХХ, 8-битовые коды — 
как 0000ХХХХ или 1111ХХХХ, 12-битовые коды имеют вид 00000000ХХХХ, 
00001111ХХХХ, 11110000ХХХХ или 11111111ХХХХ. 

23.7. Указанный способ кодирования дает приблизительно такой же ре¬ 
зультат, как и методы 15/15/... и 15/15/256. Средняя длина кода операции 
равна 4,87 бит. 

23Л. Н=8 при условии, что появление всех команд равновероятно и при 
этом имеется именно 256 отличных друг от друга кодов операций (маловероят¬ 
ная ситуация). 

23.9. Может быть определено 10 4-битовых кодов операций, 20 6-битовых 
кодов и 64 10-битовых кода (или 63 10-битовых кода, если одна комбинация 
10 бит резервируется в качестве кода переключения для использования до¬ 
полнительных кодов операций). 

23.10. Изучение статистических характеристик языков программирования 
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и анализ наборов команд других вычислительных систем показывают, что 
большинство команд передачи управления содержат ссылки на адреса с более 
высокими номерами (чем адрес самой команды передачи управления). Следо¬ 
вательно, использование относительного смещения со знаком можно считать 
неэффективным решением. В качестве альтернативы можно предложить рас¬ 
ширение диапазона значений смещения без знака «вперед» (в сторону боль¬ 
ших значений адреса), используя самые большие значения адресов для редко 
встречающихся обращений «назад» (к адресам с меньшими номерами). Со¬ 
гласно той же самой статистике, упомянутой выше, при выполнении команды 
передачи управления перемещение управления «вперед» относительно мало и 
обычно не превышает длины машинных кодов одного или двух операторов 
языка высокого уровня и, следовательно, значительно меньше 512-битового 
диапазона значений относительного смещения. Поэтому, например, замена 
10-битового относительного смещения со знаком на 8-битовое относительное 
смещение без знака (положительное смещение) может дать ощутимый вы¬ 
игрыш. 

23.11. При таких обращениях к данным при использовании наиболее ком¬ 
пактных форм представления (в большинстве случаев в виде прямых корот¬ 
ких скаляров) требуется 18 бит для каждой ссылки. Подобное представление 
следует признать существенно избыточным. В качестве альтернативного реше¬ 
ния можно предложить использование нового типа ссылки к данным, имею¬ 
щего вид 

локальн_скаляр_ссылка: : = смещ7 1, 

где ссылка на сегмент данных «контекст» задается в явном виде (значение 
неявно заданного селектора сегмента равно 0000 00). Для этого вместо 
18 бит достаточно 8 бит. С целью дальнейшего сокращения избыточности па¬ 
раметр смещ7 можно было бы определить как байтовое смещение относи¬ 
тельно конца данных (определяемых системой) в сегменте данных «контекст». 
(Для того чтобы гарантировать корректную идентификацию ссылок к дан¬ 
ным такого типа, следует внести изменения в форму представления трех су¬ 
ществующих типов (см. рис. 18.2), а именно использовать для их обозначения 
не 2 бит, а 3 бит.) 

23.12. Ответ утвердительный. Следует ввести команду итерации. 
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